首先看一下我们的效果图。
这个颜色可能搭配的有些不合适,但基本功能大都实现了。就是你和你同桌对话,你发的消息在你的左侧,而在他设备的右侧。
首先先写好整体的框架,在一个大容器中放两个盒子,分别是左侧和右侧的界面。然后每个盒子里面包含了三大部分:头部、内容区、和底部。只要写好一侧,另一侧进行粘贴复制就可以了。
首先定义一个大的
来盛放左右两个盒子。
<div id = "main"> //左侧聊天界面 <div id = "box"> <div id = "top"><span>你</span></div> <div id = "content"> <select multiple="multiple" id="leftcontent"> </select> </div> <div id = "bottom"> <input type = "text" class = "sendText" id = "leftText" /> <input type = "button" id = "leftdBtn" class="sendBtn" value = "发送"> </div> </div> //右侧聊天界面 <div id = "box"> <div id = "top"><span>同桌</span></div> <div id = "content"> <select multiple="multiple" id="rightcontent"> </select> </div> <div id = "bottom"> <input type = "text" class = "sendText" id = "rightText" /> <input type = "button" id = "rightBtn" class="sendBtn" value = "发送"> </div> </div> </div>
首先这两个盒子的代码不是复制粘贴就直接可以的。还必须注意以下不同:
<div id = "content"> <select multiple="multiple" id="rightcontent"> </select> </div>
select中的id得不同。我们一般都是
option1
option2
option3
这样使用。而在这儿使用select标签是当你和你同桌聊了一屏的天时,它有滚动条来 上下滑动看你们都聊了些什么。再上面的基础上增加一些css样式,这样界面效果就出来了。
接下来就是要写jquery代码的时候了。首先想一下你在你这边说的话既要出现在你的设备右侧,又要出现在你同桌设备的左侧?
我们先对你的界面左侧进行发消息控制,在写了文本之后,按发送按钮让它出现在你界面的右侧,同时也出现在你同桌设备的左侧。
我们要按照以下步骤来实现:
1。获得你输入的文本框中的内容。
2。生成一个option标签。
2.1 生成标签的样式即生成的span标签在你的设备的右侧进行定位并 显示。
2.2 对生成的标签进行内容的插入即插入文本框中的内容
3。将option标签追加到你的select中。
4。将option标签在你同桌设备的左侧进行定位显示。
5。清除文本框中的内容。
function sendLeft(){
//1.获得你输入的文本框中的内容。
var text = $("#leftText").val();
//2。生成一个span标签。
var option = $("`<option></option>`");
// 2.1 生成标签的样式即生成的span标签在你的设备的右侧进行定位并显示。
var len = text.length;
option.css("width", len * 15 + "px");
option.css("marginLeft", 350 - len * 15 - 60 + "px");
//2.2 生成标签的内容
option.html(text);
//3. 将内容追加到select中。
$("#leftcontent").append(option);
//4. 追加生成的标签(右侧)
var option1 = $("<option></option>");
option1.addClass("optionRight");
option1.css("width", len * 15 + "px");
option1.css("marginLeft", 10 +"px");
option1.html(text);
$("#rightcontent").append(option1);
//5. 清除文本框的内容
$("#leftText").val("");
}
}
同样再对你同桌的设备方进行显示的时候,和左侧的大同小异。
自己写一下就可以。
在写了左侧和右侧发送的消息函数之后,此时还不能进行消息发送,因为还没有进行事件绑定。首先发送消息有两种方式:
①。按钮发送
按钮发送就需要为按钮绑定事件
$("#leftdBtn").bind("click", sendLeft);
$("#rightBtn").bind("click", sendRight);
②。回车发送
$(document).keydown(function(event){
var txt1 = $("#leftText").val();
var txt2 = $("#rightText").val()
if(event.keyCode == 13){
if( txt1.trim() != ""){
sendLeft();
}
if(txt2.trim() != ""){
sendRight();
}
}
});
最后附上完整的源代码:
<!DOCTYPE html>
<html>
<head>
<meta charset = "utf-8"/>
<title>模仿微信聊天</title>
<script type="text/javascript" src = "http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<style type="text/css">
*{
margin: 0px;
padding: 0px;
}
#main{
width: 90%;
margin: 10px auto;
}
#box{
float: left;
margin:20px 120px;
}
#top{
width: 310px;
padding: 10px 20px;
color: white;
background-color: lightgreen;
font-size: 18px;
font-family: "微软雅黑";
font-weight: bold;
}
#content{
background-color: white;
}
select{
width: 350px;
height: 470px;
background-color: white;
padding: 10px;
border:2px solid red;
}
#bottom{
width: 310px;
background-color: red;
padding: 10px 20px;
}
.sendText{
height: 25px;
width: 210px;
font-size: 16px;
}
.sendBtn{
width: 65px;
height: 30px;
float: right;
background-color: gold;
color: white;
text-align: center;
font-size: 18px;
}
span{
background-color: lightgreen;
color: #000;
padding: 10px 30px;
}
option{
padding: 5px 10px;
margin-top:10px;
border-radius:5px;
width: 10px;
min-height: 20px;
}
.optionRight{
background-color: lightgreen;
}
.optionLeft{
background-color: lightblue;
}
</style>
<script>
$(function(){
$("#leftdBtn").bind("click", sendLeft);
$("#rightBtn").bind("click", sendRight);
function sendLeft(){
//1. 获取输入框中的内容
var text = $("#leftText").val();
//2. 生成标签
var option = $("<option></option>");
option.addClass("optionLeft");
//2.1 生成标签的样式
var len = text.length;
//option.css("width", len * 15 + "px","marginLeft", 350 - len * 15 - 60 + "px")
option.css("width", len * 15 + "px");
option.css("marginLeft", 350 - len * 15 - 60 + "px");
//2.2 生成标签的内容
option.html(text);
//3. 将内容追加到select中。
$("#leftcontent").append(option);
//4. 追加生成的标签(右侧)
var option1 = $("<option></option>");
option1.addClass("optionRight");
option1.css("width", len * 15 + "px");
option1.css("marginLeft", 10 +"px");
option1.html(text);
$("#rightcontent").append(option1);
//5. 清除文本框的内容
$("#leftText").val("");
}
function sendRight(){
//1. 获取输入框中的内容
var text = $("#rightText").val();
//2. 生成标签
var option = $("<option></option>");
option.addClass("optionLeft");
//2.1 生成标签的样式
var len = text.length;
//option.css("width", len * 15 + "px","marginLeft", 350 - len * 15 - 60 + "px")
option.css("width", len * 15 + "px");
option.css("marginLeft", 350 - len * 15 - 60 + "px");
//2.2 生成标签的内容
option.html(text);
//3. 将内容追加到select中。
$("#rightcontent").append(option);
//4. 追加生成的标签(右侧)
var option1 = $("<option></option>");
option1.addClass("optionRight");
option1.css("width", len * 15 + "px");
option1.css("marginLeft", 10 +"px");
option1.html(text);
$("#leftcontent").append(option1);
$("#rightText").val("");
}
$(document).keydown(function(event){
var txt1 = $("#leftText").val();
var txt2 = $("#rightText").val()
if(event.keyCode == 13){
if( txt1.trim() != ""){
sendLeft();
}
if(txt2.trim() != ""){
sendRight();
}
}
});
})
</script>
</head>
<body>
<div id = "main">
<div id = "box">
<div id = "top"><span>你</span></div>
<div id = "content">
<select multiple="multiple" id="leftcontent">
</select>
</div>
<div id = "bottom">
<input type = "text" class = "sendText" id = "leftText" />
<input type = "button" id = "leftdBtn" class="sendBtn" value = "发送">
</div>
</div>
<div id = "box">
<div id = "top"><span>同桌</span></div>
<div id = "content">
<select multiple="multiple" id="rightcontent">
</select>
</div>
<div id = "bottom">
<input type = "text" class = "sendText" id = "rightText" />
<input type = "button" id = "rightBtn" class="sendBtn" value = "发送">
</div>
</div>
</div>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# jquery微信聊天界面
# jquery微信聊天
# jquery聊天界面
# jquery添加div实现消息聊天框
# jQuery实现聊天对话框
# jquery实现聊天机器人
# JS(jQuery)实现聊天接收到消息语言自动提醒功能详解【提示“您有新的消息请注意查收”】
# 基于jQuery实现简单人工智能聊天室
# 使用jQuery调用XML实现无刷新即时聊天
# javascript和jQuery实现网页实时聊天的ajax长轮询
# PHP+jquery+ajax实现即时聊天功能实例
# JavaScript/jQuery、HTML、CSS 构建 Web IM 远程及时聊天通信程序
# jQuery实现简易聊天框
# 框中
# 出现在
# 和你
# 写了
# 绑定
# 聊了
# 写好
# 就可以
# 文本框
# 都是
# 还没有
# 在他
# 你在
# 当你
# 而在
# 三大
# 些什么
# 这两个
# 微软
# 看你
相关文章:
建站之星导航配置指南:自助建站与SEO优化全解析
名字制作网站免费,所有小说网站的名字?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
建站主机空间推荐 高性价比配置与快速部署方案解析
建站主机解析:虚拟主机配置与服务器选择指南
如何基于云服务器快速搭建个人网站?
网站图片在线制作软件,怎么在图片上做链接?
广州商城建站系统开发成本与周期如何控制?
建站之星与建站宝盒如何选择最佳方案?
定制建站流程步骤详解:一站式方案设计与开发指南
如何在宝塔面板创建新站点?
临沂网站制作企业,临沂第三中学官方网站?
如何用PHP快速搭建高效网站?分步指南
如何通过免费商城建站系统源码自定义网站主题与功能?
如何快速搭建高效服务器建站系统?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
临沂网站制作公司有哪些,临沂第四中学官网?
潮流网站制作头像软件下载,适合母子的网名有哪些?
如何在VPS电脑上快速搭建网站?
PHP正则匹配日期和时间(时间戳转换)的实例代码
建站之星代理如何获取技术支持?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何快速搭建安全的FTP站点?
c++怎么用jemalloc c++替换默认内存分配器【性能】
建站之星安装后如何配置SEO及设计样式?
如何用花生壳三步快速搭建专属网站?
Android自定义控件实现温度旋转按钮效果
济南企业网站制作公司,济南社保单位网上缴费步骤?
如何通过IIS搭建网站并配置访问权限?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
如何在万网ECS上快速搭建专属网站?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
网站制作公司排行榜,抖音怎样做个人官方网站
微信h5制作网站有哪些,免费微信H5页面制作工具?
建站之星CMS五站合一模板配置与SEO优化指南
如何快速搭建高效简练网站?
建站之星安装模板失败:服务器环境不兼容?
如何通过cPanel快速搭建网站?
学校为何禁止电信移动建设网站?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
建站为何优先选择香港服务器?
如何通过万网虚拟主机快速搭建网站?
,交易猫的商品怎么发布到网站上去?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
如何有效防御Web建站篡改攻击?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
建站之星安装提示数据库无法连接如何解决?
*请认真填写需求信息,我们会在24小时内与您取得联系。