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 相关文章推荐
在你的网页中嵌入外部网页的方法
Apr 02 Javascript
用javascript实现改变TEXTAREA滚动条和按钮的颜色,以及怎样让滚动条变得扁平
Apr 20 Javascript
js 小贴士一星期合集
Apr 07 Javascript
JS与C#编码解码
Dec 03 Javascript
js读取cookie方法总结
Oct 31 Javascript
JavaScript记录光标在编辑器中位置的实现方法
Apr 22 Javascript
JS获取和修改元素样式的实例代码
Aug 06 Javascript
一个可复用的vue分页组件
May 15 Javascript
解决vue 打包发布去#和页面空白的问题
Sep 04 Javascript
vue的for循环使用方法
Feb 12 Javascript
Vue简单封装axios之解决post请求后端接收不到参数问题
Feb 16 Javascript
利用JavaScript模拟京东按键输入功能
Dec 01 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取整函数:ceil,floor,round,intval的区别详细解析
2013/08/31 PHP
PHP调用JAVA的WebService简单实例
2014/03/11 PHP
php + WebUploader实现图片批量上传功能
2019/05/06 PHP
ThinkPHP 5.x远程命令执行漏洞复现
2019/09/23 PHP
TNC vs RR BO3 第一场 2.14
2021/03/10 DOTA
firefox和IE系列的相关区别整理 以备后用
2009/12/28 Javascript
基于JQuery的一个简单的鼠标跟随提示效果
2010/09/23 Javascript
理解JavaScript中的对象 推荐
2011/01/09 Javascript
JQuery判断子iframe何时加载完成解决方案
2013/08/20 Javascript
JavaScript中for..in循环陷阱介绍
2013/11/12 Javascript
js Date概念详细介绍
2013/11/22 Javascript
自己使用js/jquery写的一个定制对话框控件
2014/05/02 Javascript
js实现div闪烁原理及实现代码
2014/06/24 Javascript
JavaScript中具名函数的多种调用方式总结
2014/11/08 Javascript
JS实现带缓冲效果打开、关闭、移动一个层的方法
2015/05/09 Javascript
解决webpack -p压缩打包react报语法错误的方法
2017/07/03 Javascript
JavaScript中window和document用法详解
2020/07/28 Javascript
解决nuxt页面中mounted、created、watch执行两遍的问题
2020/11/05 Javascript
python使用urllib2模块获取gravatar头像实例
2013/12/18 Python
python批量提交沙箱问题实例
2014/10/08 Python
django数据库migrate失败的解决方法解析
2018/02/08 Python
在Python中调用Ping命令,批量IP的方法
2019/01/26 Python
PyTorch中Tensor的维度变换实现
2019/08/18 Python
Python中最好用的命令行参数解析工具(argparse)
2019/08/23 Python
python将字典列表导出为Excel文件的方法
2019/09/02 Python
Pycharm如何导入python文件及解决报错问题
2020/05/10 Python
HTML5 canvas基本绘图之绘制五角星
2016/06/27 HTML / CSS
HTML5实现移动端复制功能
2018/04/19 HTML / CSS
英国最大的奢侈珠宝和手表网站:C W Sellors
2017/02/10 全球购物
英国婴儿和儿童服装网站:Vertbaudet
2018/04/02 全球购物
这段代码难道不该打印出56吗
2013/02/27 面试题
工艺工程师工作职责
2013/11/23 职场文书
拓展培训心得体会
2014/01/04 职场文书
写求职信要注意什么问题
2014/04/12 职场文书
机关作风整顿个人剖析材料
2014/10/06 职场文书
tomcat默认最大连接数及相关调整方法
2022/05/06 Servers