JavaScript仿聊天室聊天记录
网络编程 2021-07-04 19:20www.168986.cn编程入门
这篇文章主要为大家详细介绍了JavaScript仿聊天室聊天记录实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了js仿聊天室聊天记录的具体代码,供大家参考,具体内容如下
参考样式(css自定义聊天窗口样式)
功能描述
1. 用户在微信公众号里发送内容,参与活动
2. 后台提供类似聊天室的窗口显示用户实时发布的内容
界面截图
代码
body { padding: 0; margin: 0; background: -moz-linear-gradient(-45deg, #183850 0, #183850 25%, #192c46 50%, #22254c 75%, #22254c 100%); background: -webkit-linear-gradient(-45deg, #183850 0, #183850 25%, #192c46 50%, #22254c 75%, #22254c 100%); background-repeat: no-repeat; background-attachment: fixed; } ::-webkit-scrollbar { width: 10px; } ::-webkit-scrollbar-track { border-radius: 10px; background-color: rgba(25, 147, 147, 0.1); } ::-webkit-scrollbar-thumb { border-radius: 10px; background-color: rgba(25, 147, 147, 0.2); } .chat-thread { margin: 24px auto 0 auto; padding: 0 20px 0 0; list-style: none; overflow-y: scroll; overflow-x: hidden; } .chat-thread .li { position: relative; clear: both; display: inline-block; padding: 16px 40px 16px 20px; margin: 0 0 20px 0; font: 16px/20px 'Noto Sans', sans-serif; border-radius: 10px; background-color: rgba(25, 147, 147, 0.2); } / Chat - Avatar / .chat-thread .img { width: 50px; height: 50px; border-radius: 50px; content: ''; float:left; } / Chat - Speech Bubble Arrow / .chat-thread li:after { position: absolute; : 15px; content: ''; width: 0; height: 0; border-: 15px solid rgba(25, 147, 147, 0.2); } .chat-thread li:nth-child(odd) { animation: show-chat-odd 0.15s 1 ease-in; -moz-animation: show-chat-odd 0.15s 1 ease-in; -webkit-animation: show-chat-odd 0.15s 1 ease-in; float: right; margin-right: 80px; color: #0AD5C1; } .chat-thread li:nth-child(odd):before { right: -80px; } .chat-thread li:nth-child(odd):after { border-right: 15px solid transparent; right: -15px; } .chat-thread li:nth-child(even) { animation: show-chat-even 0.15s 1 ease-in; -moz-animation: show-chat-even 0.15s 1 ease-in; -webkit-animation: show-chat-even 0.15s 1 ease-in; float: left; margin-left: 80px; color: #0EC879; } .chat-thread li:nth-child(even):before { left: -80px; } .chat-thread li:nth-child(even):after { border-left: 15px solid transparent; left: -15px; } .chat-window { position: fixed; bottom: 18px; } .chat-window-message { width: 100%; height: 48px; font: 32px/48px 'Noto Sans', sans-serif; background: none; color: #0AD5C1; border: 0; border-bottom: 1px solid rgba(25, 147, 147, 0.2); outline: none; } / Small screens / @media all and (max-width: 767px) { .chat-thread { width: 90%; height: 500px; } .chat-window { left: 5%; width: 90%; } } / Medium and large screens / @media all and (min-width: 768px) { .chat-thread { width: 70%; height: 500px; } .chat-window { left: 25%; width: 50%; } } @keyframes show-chat-even { 0% { margin-left: -480px; } 100% { margin-left: 0; } } @-moz-keyframes show-chat-even { 0% { margin-left: -480px; } 100% { margin-left: 0; } } @-webkit-keyframes show-chat-even { 0% { margin-left: -480px; } 100% { margin-left: 0; } } @keyframes show-chat-odd { 0% { margin-right: -480px; } 100% { margin-right: 0; } } @-moz-keyframes show-chat-odd { 0% { margin-right: -480px; } 100% { margin-right: 0; } } @-webkit-keyframes show-chat-odd { 0% { margin-right: -480px; } 100% { margin-right: 0; } } .credits{ text-align:center; margin-:35px; color: rgba(255, 255, 255, 0.35); font-family: 'Noto Sans', sans-serif; } .credits a{ text-decoration:none; color: rgba(255, 255, 255, 0.35); }
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>红包详情</title> <meta name="keywords" content="keyword1,keyword2,keyword3"> <meta name="description" content="this is my page"> <meta name="content-type" content="text/html; charset=UTF-8"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <script src="../js/jquery-1.7.2.min.js"></script> <link rel="stylesheet" href="css/style.css" media="screen" type="text/css" /> </head> <body > <div id="convo" class="chat-thread"></div> </body> <script type="text/javascript"> var maxId = 0; var ip = "http://..."; var imgArr=new Array(); var contentArr=new Array(); var canAdd = false; function loadUser(){ $.post("../servlet/luckDraw", // 访问后台查询数据 { type : "messageList", limit : 5, maxId : maxId, time : new Date() }, function(data,status){ var jsonobj=eval('('+data+')'); if(jsonobj.code=="200"){ canAdd = false; imgArr=new Array(); contentArr=new Array(); var jsonarr = jsonobj.list; var str = ""; for(var i=0;i<jsonarr.length;i++){ //console.log(time1); imgArr[i] = ip+jsonarr[i].headImg; contentArr[i] = jsonarr[i].content; maxId = jsonarr[i].id; } canAdd = true; } }); } loadUser(); //var t1 = window.setTimeout(time(1),1000); var t1 = window.setInterval(time,3000); function time(){ if(!canAdd) return; if(imgArr.length==0){ loadUser(); return; } var img = imgArr[0]; var content = contentArr[0]; imgArr.splice(0, 1); contentArr.splice(0, 1); $("#convo").append('<div>'+ '<div style="width:60px;height:50px;float:left"> <img alt="" height="50px" width="50px" class="img" src="'+img+'"></div>'+ '<div style="width:90%;float:left;"><span class="li">'+content+'</span> </div>'+ '</div>'); var e=document.getElementById("convo");//保持滚动条一直在最底部 e.scrollTop=e.scrollHeight; } </script> </html>
String sql = "SELECT c.,u.nickName,u.headImg " + "from wx_costomersendmessage c,bid_user u " + "where c.openId=u.openId and c.id>"+maxId +" order by c.id Limit 0,"+limit;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:javascript实现文字无缝滚动
下一篇:基于jQuery实现顶部导航栏功能
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程