JS简单仿QQ聊天工具的制作
刚接触JS,对其充满了好奇,利用刚学到的一点知识,写了一个简单的仿QQ聊天的东西,其中还有很多的不足之处,有待慢慢提高。
功能:1、在输入框中输入内容,点击发送,即可在上方显示所输入内容。
2、点击‘笑脸’按钮,可选择笑脸进行发送。
不足之处:1、没有添加键盘事件,暂不可以用键盘进行发送内容;
2、在输入框中输入“请输入内容”时,系统并不会发送,因为此代码尚未对手动输入“请输入内容”和系统自动显示的“请输入内容”进行判断。
3、点击“笑脸”时,其图片路径会显示在input框中,也是不合理之处。
由于刚开始进行研究,故出现的bug也是比较的多的。我会在以后慢慢的进行改进。写下这些,是对自己的成长进行一个记录。希望可以越来越好。
HTML代码:
<div class="bgdiv" id='wrap'>
<div class="name">大大的力量</div>
<ul id="ul1"></ul>
<div class="btdiv">
<div class="ipt">
<div class="btns_1">
<a href="javascript:;" class="btn_face" id="btn3"></a>
</div>
<form>
<input type="text" id="ipt1" value="" />
<input type="button" value="发送" id="btn1" />
</form>
</div>
<ul id="face">
<li><img src="img/face/f1.png" /></li>
<li><img src="img/face/f1.png" /></li>
<li><img src="img/face/f3.png" /></li>
<li><img src="img/face/f4.png" /></li>
<li><img src="img/face/f5.png" /></li>
<li><img src="img/face/f1.png" /></li>
<li><img src="img/face/f1.png" /></li>
<li><img src="img/face/f3.png" /></li>
<li><img src="img/face/f4.png" /></li>
<li><img src="img/face/f5.png" /></li>
</ul>
<div id="add"><img src="img/add.jpg" /></div>
</div>
</div>
CSS代码:
*{margin:;padding:;}
.bgdiv{width:338px;height:459px;margin:60px auto 0;padding:155px 28px 130px 34px;background:url(img/320.png) no-repeat;font-size:12px;position:relative;}
.name{width:100%;height:45px;line-height:45px;text-align:center;font-size:16px;font-family:'微软雅黑';color:#fff;}
#ul1{width:322px;height:350px;padding:10px 8px;overflow-y:auto;}
#ul1 li{list-style:none;width:100%;margin-bottom:10px;}
#ul1 li img{width:30px;height:30px;}
#ul1 a{max-width:140px;padding:3px;line-height:18px;display:inline-block;border:1px solid #999;border-radius:5px;color:#000;word-break:break-all;text-align:left;box-shadow:0 1px 2px #999;vertical-align: top;}
#ul1 a img{width:20px;height:20px;vertical-align: middle;}
.btdiv{position:absolute;bottom:130px;left:34px;width:337px;}
.ipt{width:321px;height:32px;padding:7px 8px;background:url(img/inpt_bg.jpg) repeat-x left center;}
.btns_1{float:left;}
.btns_1 a{display:inline-block;text-align:left;margin-top:3px;}
.btn_add{width:30px;height:31px;background:url(img/btn_1.jpg) no-repeat;background-position:0 0;}
.btn_face{width:30px;height:31px;background:url(img/btn_1.jpg) no-repeat;background-position:100% 0;*+margin-left:6px;}
form{width:280px;height:32px;float:right;}
#ipt1{width:222px;height:30px;padding-left:3px;line-height:30px;border:1px solid #c3c3c3;border-radius:6px;background:#fff;vertical-align:middle;}
#btn1{width:40px;height:32px;background:url(img/btn_sent.jpg) no-repeat;border:;vertical-align:middle;text-indent:9999px;margin-left: 4px;}
#face{width:330px;overflow:hidden;padding:8px 7px 0 0;background:#CFD6DE;display:none;}
#face li{width:40px;height:40px;line-height:50px;margin-bottom:8px;text-align:center;margin-left:7px;float:left;list-style:none;}
#add{width:337px;height:156px;display:none;}
JS代码:
<script>
window.onload=function(){
var oDiv=document.getElementById('wrap');
var oUl1=document.getElementById('ul1');
var aLi=oUl1.getElementsByTagName('li');
var oIpt=document.getElementById('ipt1');
var oBtn1=document.getElementById('btn1');
var oBtn2=document.getElementById('btn2');
var oBtn3=document.getElementById('btn3');
var oDiv1=document.getElementById('face');
var aLi1=document.getElementsByTagName('li');
var oDiv2=document.getElementById('add');
oBtn1.onclick=function(){
if(oIpt.value==''){
oIpt.value='请输入内容';
}
else if(oIpt.value=='请输入内容'){
oUl1.innerHTML=oUl1.innerHTML;
}
else{
oUl1.innerHTML=oUl1.innerHTML+'<li><img src="img/peo3.jpg" /><a>'+oIpt.value+'</a></li>';
oIpt.value='';
}
say();
}
oDiv1.onOff=true;
oBtn3.onclick=function(){
if(oDiv1.onOff){
oDiv1.style.display='block';
oUl1.style.height='244px' ;
oDiv1.onOff=false;
}
else{
oDiv1.style.display='none';
oUl1.style.height='350px' ;
oDiv1.onOff=true; }
}
for(var i=0;i<aLi1.length;i++){
aLi1[i].onmouseover=function(){
this.style.background='#999';
}
aLi1[i].onmouseout=function(){
this.style.background='';
}
aLi1[i].onclick=function(){
oIpt.value=oIpt.value+this.innerHTML;
say();
}
}
function say(){
for(var i=0;i<aLi.length;i++){
var oImg=aLi[i].getElementsByTagName('img')[0];
var oA=aLi[i].getElementsByTagName('a')[0];
if(i%2==0){
aLi[i].style.textAlign='left';
oA.style.background='#8bc5f2';
oImg.src='img/peo3.jpg';
oImg.style.cssFloat='left';
oImg.style.marginRight='6px';
oImg.style.styleFloat='left';
}
else{
aLi[i].style.textAlign='right';
oA.style.background='#eaebed';
oImg.src='img/peo2.jpg';
oImg.style.cssFloat='right';
oImg.style.marginLeft='6px';
oImg.style.styleFloat='right';
}
}
} }
</script>
显示效果如下:

PK(B91`V`@]{~%H@N($PG.jpg)
JS简单仿QQ聊天工具的制作的更多相关文章
- Socket实现仿QQ聊天(可部署于广域网)附源码(1)-简介
1.前言 本次实现的这个聊天工具是我去年c#程序设计课程所写的Socket仿QQ聊天,由于当时候没有自己的服务器,只能在机房局域网内进行测试,最近在腾讯云上买了一台云主机(本人学生党,腾讯云有个学生专 ...
- 仿QQ聊天程序(java)
仿QQ聊天程序 转载:牟尼的专栏 http://blog.csdn.net/u012027907 一.设计内容及要求 1.1综述 A.系统概述 我们要做的就是类似QQ这样的面向企业内部的聊天软件,基本 ...
- 高仿qq聊天界面
高仿qq聊天界面,给有需要的人,界面效果如下: 真心觉得做界面非常痛苦,给有需要的朋友. chat.xml <?xml version="1.0" encoding=&quo ...
- Android特效专辑(六)——仿QQ聊天撒花特效,无形装逼,最为致命
Android特效专辑(六)--仿QQ聊天撒花特效,无形装逼,最为致命 我的关于特效的专辑已经在CSDN上申请了一个专栏--http://blog.csdn.net/column/details/li ...
- WPF仿QQ聊天框表情文字混排实现
原文:WPF仿QQ聊天框表情文字混排实现 二话不说.先上图 图中分别有文件.文本+表情.纯文本的展示,对于同一个list不同的展示形式,很明显,应该用多个DataTemplate,那么也就需要Data ...
- Android—简单的仿QQ聊天界面
最近仿照QQ聊天做了一个类似界面,先看下界面组成(画面不太美凑合凑合呗,,,,):
- C# 实现简单仿QQ登陆注册功能
闲来没事,想做一个仿QQ登陆注册的winform,于是利用工作之余,根据自己的掌握和查阅的资料,历时4天修改完成,新手水平,希望和大家共同学习进步,有不同见解希望提出! 废话不多说,进入正题: 先来看 ...
- Netty 仿QQ聊天室 (实战二)
Netty 聊天器(百万级流量实战二):仿QQ客户端 疯狂创客圈 Java 分布式聊天室[ 亿级流量]实战系列之15 [博客园 总入口 ] 源码IDEA工程获取链接:Java 聊天室 实战 源码 写在 ...
- js五道经典练习题--第二道仿qq聊天框
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
随机推荐
- windows下把Apache加入系统服务
始 --- 运行,输入cmd,再打开一个命令提示符.分别输入如下命令(每行回车) cd到Apache24\binhttpd.exe-k install-n"servicename" ...
- 【十分钟教会你汇编】MIPS编程入门(妈妈说标题要高大上,才会有人看>_<!)
无意中找到一篇十分好用,而且篇幅也不是很大的入门教程,通篇阅后,再把“栗子”敲一遍,基本可以有一个比较理性的认识,从而方便更好地进一步深入学习. 废话不多说,上干货(英语好的直接跳过本人的渣翻译了哈— ...
- Java并发——使用Condition线程间通信
线程间通信 线程之间除了同步互斥,还要考虑通信.在Java5之前我们的通信方式为:wait 和 notify.Condition的优势是支持多路等待,即可以定义多个Condition,每个condit ...
- Java eclipse生成doc文档
这里讲解下eclipse成为doc文档,首先代码: /** * @author szy * @version 1.0 */ package com.founder.sun; class Cat{ pu ...
- Sql触发器脚本
ALTER Trigger [dbo].[test] --新建触发器 On [dbo].[test1] --在test1表中创建触发器 for insert --触发条件 As --事件触发后所要做的 ...
- 20160406javaweb 之JDBC简单案例
前几天写的user注册登录注销案例,没有用到数据库,现在做出改动,使用数据库存储信息: 一.首先我们需要建立一个数据库: 如下图: 创建数据库的代码如下: -- 导出 database02 的数据库结 ...
- 10个你可能不知道的JavaScript小技巧
1.变量转换 看起来很简单,但据我所看到的,使用构造函数,像Array()或者Number()来进行变量转换是常用的做法.始终使用原始数据类型(有时也称为字面量)来转换变量,这种没有任何额外的影响的做 ...
- objective-c在Xcode中@property相关参数的解释
objective-c在其对象拥有成员变量时,我们为了保持代码的封装,会将成员变量设置为@protected,并为成员变量编写setter和getter方法. 如: @interface Person ...
- android中相关的图形类
Bitmap - 称作位图,一般位图的文件格式后缀为bmp,当然编码器也有很多如RGB565.RGB888.作为一种逐像素的显示对象执行效率高,但是缺点也很明显存储效率低.我们理解为一种存储对象比较好 ...
- Codevs 2776 寻找代表元(二分图匹配)
2776 寻找代表元 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题目描述 Description 广州二中苏元实验学校一共有n个社团,分别用1到n编号. 广州二 ...