JavaScript实现简易聊天对话框(加滚动条)


Posted in Javascript onFebruary 10, 2020

今天看了几个JS的视频,老师布置了一个编写一个简易聊天对话框的任务,没有涉及到Ajax.主要实现了切换头像模拟两方的聊天情况,样式比较简单,后期可以进行美化。

需要注意的地方是我是用的ul li列表来实现元素的添加,这样更利于样式的设置,每添加一个对话框需要清除一下浮动,不然会出现连续几个对话框出现在一行的现象。

代码如下:

<!DOCTYPE html>

<html>

<head>
<meta charset="utf-8">
<title>聊天对话框</title>
<style type="text/css">
#container{
width: 250px;
height: 350px;
border:1px solid #7b6b6b;
margin: 0 auto;
position: relative;

}

#content{
width: 250px;
height: 300px;
border-bottom: 1px solid #ccc;
overflow-y: auto;

}

#content ul{
margin: 0;
padding: 0;

}

#Img{
width: 30px;
height: 30px;
position: absolute;
left: 10px;
top: 310px;
border-radius: 15px;

}

#txt{
margin: 0;
position: absolute;
left: 50px;
top: 315px;
border-radius: 2px;
border:1px solid #ccc;
width: 133px;
height: 18px;

}

#btn{
margin-right: 10px;
position: absolute;
margin: 0;
left: 197px;
top: 314px;

}

#edit{
background: #ece7e766;
width: 250px;
height: 50px;

}

.showTxt{
width: auto;
height: auto;
max-width: 230px;
background: #008000a8;
border:0;
font-size: 15px;
color: white;
padding: 5px;
border-radius: 2px; 
word-break: break-all;
list-style: none;
margin-top: 5px;
display: list-item;

}

.left{
text-align: left;
margin-left: 50px;
float: left;

}

.right{
text-align: right;
margin-right: 50px;
float: right;

}

.showImg{
width: 26px;
height: 26px;
border-radius: 13px;

 

}

.leftImg{
left: 10px;
position: absolute;

}

.rightImg{
right: 10px;
position: absolute;

}

#scroll{
position: relative;

}

</style>
</head>
<body>

<div id="container">
<div id="content">
<div id="scroll">
<ul id="save"></ul>
</div>
</div>

<div id="edit">
<img src="1.jpg" id="Img">
<input type="text" name="" id="txt">
<input type="button" name="" value="发送" id="btn">
</div>
</div>
<script type="text/javascript">

 //获取元素

var oCont=document.getElementById('content');
var oImg=document.getElementById('Img');
var oTxt=document.getElementById('txt');
var oBtn=document.getElementById('btn');
var oSTxt=document.getElementsByClassName('showTxt');
var oSave=document.getElementById('save');
var num=0;

 //切换头像
oImg.οnclick=function(){
num++;
if(num%2==0)
oImg.src='1.jpg';
else
oImg.src='2.jpg';

}

 //发送事件
oBtn.οnclick= function(){
addCon();

}

function addCon(){ 
//定义需要添加的元素
var newLi=document.createElement("li");
var newImg=document.createElement('img');
//判断聊天的对象是哪一方,文字框出现在左边还是右边
 if(num%2==0){
//添加对话框
newLi.innerHTML=oTxt.value;
newLi.className='showTxt right';
oSave.appendChild(newLi); 
oTxt.value='';
 //添加头像
newImg.src=oImg.src;
newImg.className='showImg rightImg';
newLi.appendChild(newImg); 

 //清除浮动
var div = document.createElement('div');
 div.style = 'clear:both';
 oSave.appendChild(div);
 }else{
 newLi.innerHTML=oTxt.value;
newLi.className='showTxt left';
oSave.appendChild(newLi); 
oTxt.value='';
newImg.src=oImg.src;
newImg.className='showImg leftImg';
newLi.appendChild(newImg);
var div = document.createElement('div');
 div.style = 'clear:both';
 oSave.appendChild(div);

 }

}

</script>
</body>
</html>

页面结果如图:

JavaScript实现简易聊天对话框(加滚动条)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 构造函数 实例分析
Nov 26 Javascript
让低版本浏览器支持input的placeholder属性(js方法)
Apr 03 Javascript
通过复制Table生成word和excel的javascript代码
Jan 20 Javascript
JS取request值以及自动执行使用示例
Feb 24 Javascript
c#+jquery实现获取radio和checkbox的值
Sep 12 Javascript
微信小程序 特效菜单抽屉效果实例代码
Jan 11 Javascript
微信小程序 自定义消息提示框
Aug 06 Javascript
利用vue + koa2 + mockjs模拟数据的方法教程
Nov 22 Javascript
js将键值对字符串转为json字符串的方法
Mar 30 Javascript
JS函数动态传递参数的方法分析【基于arguments对象】
Jun 05 Javascript
详解Vue中组件传值的多重实现方式
Aug 16 Javascript
解决vue项目input输入框双向绑定数据不实时生效问题
Aug 05 Javascript
node.js使用 http-proxy 创建代理服务器操作示例
Feb 10 #Javascript
node.js中 redis 的安装和基本操作示例
Feb 10 #Javascript
js实现登录拖拽窗口
Feb 10 #Javascript
javascript 原型与原型链的理解及应用实例分析
Feb 10 #Javascript
在 Vue 中使用 JSX 及使用它的原因浅析
Feb 10 #Javascript
node.js使用http模块创建服务器和客户端完整示例
Feb 10 #Javascript
webpack打包优化的几个方法总结
Feb 10 #Javascript
You might like
php牛逼的面试题分享
2013/01/18 PHP
PHP中数组定义的几种方法
2013/09/01 PHP
php使用curl模拟登录后采集页面的例子
2013/11/04 PHP
利用PHP fsockopen 模拟POST/GET传送数据的方法
2015/09/22 PHP
laravel框架邮箱认证实现方法详解
2019/11/22 PHP
基于jQuery的Spin Button自定义文本框数值自增或自减
2010/07/17 Javascript
JS 排序输出实现table行号自增前端动态生成的tr
2014/08/13 Javascript
JQuery调用绑定click事件的3种写法
2015/03/28 Javascript
修改ligerui 默认确认按钮的方法
2016/12/27 Javascript
SVG描边动画
2017/02/23 Javascript
JavaScript简单计算人的年龄示例
2017/04/15 Javascript
基于LayUI分页和LayUI laypage分页的使用示例
2017/08/02 Javascript
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
2018/05/15 Javascript
Node.js模块全局安装路径配置方法
2018/05/17 Javascript
vue-router+nginx 非根路径配置方法
2018/06/30 Javascript
layui表格内放置图片,并点击放大的实例
2019/09/10 Javascript
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
使用npm命令提示: 'npm' 不是内部或外部命令,也不是可运行的程序的处理方法
2020/05/14 Javascript
echarts实现晶体球面投影的实例教程
2020/10/10 Javascript
基于JavaScript实现随机点名器
2021/02/25 Javascript
Python素数检测的方法
2015/05/11 Python
Python输出带颜色的字符串实例
2017/10/10 Python
Python中super函数用法实例分析
2019/03/18 Python
代码实例讲解python3的编码问题
2019/07/08 Python
由面试题加深对Django的认识理解
2019/07/19 Python
解决Python3 抓取微信账单信息问题
2019/07/19 Python
Keras构建神经网络踩坑(解决model.predict预测值全为0.0的问题)
2020/07/07 Python
细说CSS3中的选择符
2008/10/17 HTML / CSS
css3和jquery实现的可折叠导航菜单适合放在手机网页的导航菜单
2014/09/02 HTML / CSS
一款纯css3实现的竖形二级导航的实例教程
2014/12/11 HTML / CSS
印度尼西亚最大的电商平台:Tokopedia(印尼版淘宝)
2017/12/02 全球购物
全球游戏Keys和卡片市场:GamesDeal
2018/03/28 全球购物
Oracle的内存结构(Memory structures)
2015/06/10 面试题
医大实习自我鉴定
2013/12/07 职场文书
2014年会策划方案
2014/05/11 职场文书
2015年小学总务工作总结
2015/07/21 职场文书