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 相关文章推荐
jquery禁止回车触发表单提交
Dec 12 Javascript
JavaScript的Vue.js库入门学习教程
May 23 Javascript
JavaScript读二进制文件并用ajax传输二进制流的方法
Jul 18 Javascript
AngularJS ng-repeat数组有重复值的解决方法
Oct 23 Javascript
H5移动端适配 Flexible方案
Oct 24 Javascript
简单三步实现报表页面集成天气
Dec 15 Javascript
jQuery无缝轮播图代码
Dec 22 Javascript
jquery.validate.js 多个相同name的处理方式
Jul 10 jQuery
如何在JavaScript中优雅的提取循环内数据详解
Mar 04 Javascript
Vue项目部署的实现(阿里云+Nginx代理+PM2)
Mar 26 Javascript
详解Vue组件之间通信的七种方式
Apr 14 Javascript
为什么推荐使用JSX开发Vue3
Dec 28 Vue.js
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学习之数组值的操作
2011/04/17 PHP
php输出xml属性的方法
2015/03/19 PHP
php实现的PDO异常处理操作分析
2018/12/27 PHP
Aster vs Newbee BO3 第二场2.18
2021/03/10 DOTA
背景音乐每次刷新都可以自动更换
2007/02/01 Javascript
用JS操作FRAME中的IFRAME及其内容的实现代码
2008/07/26 Javascript
jquery下jstree简单应用 - v1.0
2011/04/14 Javascript
js中call与apply的用法小结
2013/12/28 Javascript
JS回调函数的应用简单实例
2014/09/17 Javascript
jQuery实现切换字体大小的方法
2015/03/10 Javascript
JQuery实现Ajax加载图片的方法
2015/12/24 Javascript
JavaScript类型系统之基本数据类型与包装类型
2016/01/06 Javascript
javascript学习指南之回调问题
2016/04/23 Javascript
js弹出框、对话框、提示框、弹窗实现方法总结(推荐)
2016/05/31 Javascript
jquery 标签 隔若干行加空白或者加虚线的方法
2016/12/07 Javascript
任意Json转成无序列表的方法示例
2016/12/09 Javascript
原生js实现吸顶效果
2017/03/13 Javascript
详解Vue中使用v-for语句抛出错误的解决方案
2017/05/04 Javascript
微信小程序组件 marquee实例详解
2017/06/23 Javascript
简单实现jquery隔行变色
2017/11/09 jQuery
详解vue的diff算法原理
2018/05/20 Javascript
vue的过滤器filter实例详解
2018/09/17 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
2018/11/25 Javascript
VUE实现强制渲染,强制更新
2019/10/29 Javascript
微信小程序实现图片压缩
2019/12/03 Javascript
使用Python编写vim插件的简单示例
2015/04/17 Python
Python函数中的函数(闭包)用法实例
2016/03/15 Python
Python+selenium实现截图图片并保存截取的图片
2018/01/05 Python
TFRecord文件查看包含的所有Features代码
2020/02/17 Python
HTML5中外部浏览器唤起微信分享功能的代码
2020/09/15 HTML / CSS
野兽派官方旗舰店:THE BEAST 野兽派
2016/08/05 全球购物
Nike挪威官网:Nike.com (NO)
2018/11/26 全球购物
幼师岗位求职简历的自荐信格式
2013/09/21 职场文书
模具设计与制造专业应届生求职信
2013/10/18 职场文书
2015年护士医德医风自我评价
2015/03/03 职场文书
用python画城市轮播地图
2021/05/28 Python