本文主要为大家详细介绍了jquery仿微信聊天界面的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

首先看一下我们的效果图。

这个颜色可能搭配的有些不合适,但基本功能大都实现了。就是你和你同桌对话,你发的消息在你的左侧,而在他设备的右侧。

首先先写好整体的框架,在一个大容器中放两个盒子,分别是左侧和右侧的界面。然后每个盒子里面包含了三大部分:头部、内容区、和底部。只要写好一侧,另一侧进行粘贴复制就可以了。

首先定义一个大的

来盛放左右两个盒子。

//左侧聊天界面

//右侧聊天界面

同桌

首先这两个盒子的代码不是复制粘贴就直接可以的。还必须注意以下不同:

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 = $("``");

// 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 = $("");

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();

}

}

});

最后附上完整的源代码:

模仿微信聊天

*{

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;

}

$(function(){

$("#leftdBtn").bind("click", sendLeft);

$("#rightBtn").bind("click", sendRight);

function sendLeft(){

//1. 获取输入框中的内容

var text = $("#leftText").val();

//2. 生成标签

var 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 = $("");

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.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 = $("");

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();

}

}

});

})

同桌

相关推荐:

js模拟群聊天php,jquery仿微信聊天界面实例分享相关推荐

  1. Vue3+ElementPlus网页端聊天|vue3.0仿微信/QQ界面实例

    vue3-webchat 基于vue3.0.5开发的仿微信|QQ界面桌面端聊天实例. 运用vue3.x全家桶技术+element-plus+v3layer+v3scroll搭建的仿微信/QQ界面网页聊 ...

  2. h5仿微信聊天室weChatRoom|仿微信聊天界面

    html5仿微信聊天|h5仿微信聊天室|仿微信聊天界面|仿微信群聊/单聊 平时一闲下来就撸项目代码,最近一直在开发h5仿微信聊天项目,使用到了html5+css3+zepto+iscroll+swip ...

  3. h5聊天室案例|仿微信聊天界面|多人群聊

    html5仿微信聊天室weChatRoom案例|多人群聊互动|仿微信聊天界面 该项目是使用html5+css3+zepto+swiper+wcPop等技术开发的仿微信聊天室,捣鼓调试了很长时间,在手机 ...

  4. html语音聊天室,h5聊天室模板|仿微信聊天室html5

    运用html5开发的仿微信聊天室实战项目weChatRoom,基于h5+css3+zepto+weui+wcPop+swiper等技术混合开发,整体采用flex布局模式,兼容适配各种手机屏幕,实现了消 ...

  5. 聊天室html布局,h5聊天室模板|仿微信聊天室html5

    运用 html5 开发的仿微信聊天室实战项目weChatRoom,基于h5+css3+zepto+weui+wcPop+swiper等技术混合开发,整体采用flex布局模式,兼容适配各种手机屏幕,实现 ...

  6. h5聊天页面 jquery_HTML5仿微信聊天界面、微信朋友圈实例代码

    这几天使用H5开发了一个仿微信聊天前端界面,尤其微信底部编辑器那块处理的很好,使用HTML5来开发,虽说功能效果并没有微信那么全,但是也相当不错了,可以发送消息.表情,发送的消息自动回滚定位到底部,另 ...

  7. php仿qq聊天界面,jquery仿微信聊天界面

    首先看一下我们的效果图. 这个颜色可能搭配的有些不合适,但基本功能大都实现了.就是你和你同桌对话,你发的消息在你的左侧,而在他设备的右侧. 首先先写好整体的框架,在一个大容器中放两个盒子,分别是左侧和 ...

  8. android模拟微信聊天功能,android仿微信聊天界面 语音录制功能

    本例为模仿微信聊天界面UI设计,文字发送以及语言录制UI. 1先看效果图: 第一:chat.xml设计 android:layout_width="fill_parent" and ...

  9. ReactNative聊天APP实战|仿微信聊天/朋友圈/红包界面

    项目简介 最近一直在研究RN技术,想着找个项目练练手,之前就有使用vue.react技术开发过聊天项目,这次就使用reactNative技术开发个仿微信RN版.是基于 react-native+rea ...

最新文章

  1. Python之旅.第四章.模块与包
  2. 【Groovy】编译时元编程 ( ASTTransformation#visit 方法获取 Groovy 源文件 )
  3. CSS基础(part9)--CSS背景
  4. 二:Maven中pom.xml元素详解
  5. 学法减分助手PRO小程序
  6. windows之Apache服务器搭建
  7. 码云推出企业 Git 和项目管理现场培训服务
  8. [Matlab]变量,变量名与字符串的互相转换
  9. Hyperledger Composer和Hyperledger Fabric的关系、区别及概念
  10. Magento的基本架构解析
  11. 最新的Sql笔试题及答案,部门表,用户表,客户信息表,订单表
  12. Python爬取最爱的电影并下载到本地(附源码)
  13. Win10(Win7)局域网设置共享文件夹,超全面步骤。
  14. 读后感__局外人_知其不可而为之
  15. 计算机word的关闭怎么办,为什么我的计算机word文档打开和关闭缓慢
  16. 交换机端口mtu值最大_中低端交换机修改三层接口MTU值的说明
  17. 生病吃什么水果你知道吗?
  18. 美食杰项目-登录注册
  19. .NET 经常被面试官问到的问题
  20. 哨兵2a 波段组合_遥感数据介绍—Sentinel 2A

热门文章

  1. 2019 NCTF Re WP
  2. Google 有哪些牛逼的开源项目?
  3. 无法访问srv解析_windows能连网络,可是打不开网页,出现无法解析server的DNS
  4. 51单片机PCB实物DCDC可调负电源负压+12V输入-2.5V~-9V输出500MA电流
  5. 分治与递归 | 5:主元素问题的三种解法
  6. LATEX中使用16进制颜色#FFFFFF
  7. ElasticSearch详解(一)
  8. 【优化求解】基于水母搜索优化器JS算法求解多目标优化问题matlab源码
  9. Python覆盖率工具
  10. python 书写 “中国”