JavaScript模拟可展开、拖动与关闭的聊天窗口实例


Posted in Javascript onMay 12, 2015

用JavaScript实现的仿QQ聊天窗口,可以展开层、拖动层、关闭层,还可以简单发消息,很不错吧,而且代码也不多,适合新手研究,也比较实用,你可以在此基础上扩展很多JS+CSS应用。

<!--CTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dt-->
<html>
<head>
<title>层展开、层拖动、层关闭</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css" media="all" rel="stylesheet">
 <!--
 body {
  text-align:left;
  margin:0;
  font:normal 12px Verdana, Arial;
  background:#FFEEFF
 }
 form {
  margin:0;
  font:normal 12px Verdana, Arial;
 }
 table,input {
  font:normal 12px Verdana, Arial;
 }
 a:link,a:visited{
  text-decoration:none;
  color:#333333;
 }
 a:hover{
  text-decoration:none;
  color:#FF6600
 }
 #main {
  width:400px;
  position:absolute;
  left:600px;
  top:100px;
  background:#EFEFFF;
  text-align:left;
  filter:Alpha(opacity=90)
 }
 #ChatHead {
  text-align:right;
  padding:3px;
  border:1px solid #003399;
  background:#DCDCFF;
  font-size:11px;
  color:#3366FF;
  cursor:move;
 }
 #ChatHead a:link,#ChatHead a:visited, {
  font-size:14px;
  font-weight:bold;
  padding:0 3px
 }
 #ChatBody {
  border:1px solid #003399;
  border-top:none;
  padding:2px;
 }
 #ChatContent {
  height:200px;
  padding:6px;
  overflow-y:scroll;
  word-break: break-all
 }
 #ChatBtn {
  border-top:1px solid #003399;
  padding:2px
 }
 -->
 </style><script language="javascript" type="text/javascript">
 <!--
 function $(d){return document.getElementById(d);}
 function gs(d){var t=$(d);if (t){return t.style;}else{return null;}}
 function gs2(d,a){
  if (d.currentStyle){ 
   var curVal=d.currentStyle[a]
  }else{ 
   var curVal=document.defaultView.getComputedStyle(d, null)[a]
  } 
  return curVal;
 }
 function ChatHidden(){gs("ChatBody").display = "none";}
 function ChatShow(){gs("ChatBody").display = "";}
 function ChatClose(){gs("main").display = "none";}
 function ChatSend(obj){
  var o = obj.ChatValue;
  if (o.value.length>0){
   $("ChatContent").innerHTML += "<strong>Akon说:</strong>"+o.value+"<br/>";
   o.value='';
  }
 }
 if (document.getElementById){
  (
   function(){
    if (window.opera){ document.write("<input type='hidden' id='Q' value=' '>"); }
    var n = 500;
    var dragok = false;
    var y,x,d,dy,dx;
    function move(e)
    {
     if (!e) e = window.event;
     if (dragok){
      d.style.left = dx + e.clientX - x + "px";
      d.style.top = dy + e.clientY - y + "px";
      return false;
     }
    }
    function down(e){
     if (!e) e = window.event;
     var temp = (typeof e.target != "undefined")?e.target:e.srcElement;
     if (temp.tagName != "HTML"|"BODY" && temp.className != "dragclass"){
      temp = (typeof temp.parentNode != "undefined")?temp.parentNode:temp.parentElement;
     }
     if('TR'==temp.tagName){
      temp = (typeof temp.parentNode != "undefined")?temp.parentNode:temp.parentElement;
      temp = (typeof temp.parentNode != "undefined")?temp.parentNode:temp.parentElement;
      temp = (typeof temp.parentNode != "undefined")?temp.parentNode:temp.parentElement;
     }
     if (temp.className == "dragclass"){
      if (window.opera){ document.getElementById("Q").focus(); }
      dragok = true;
      temp.style.zIndex = n++;
      d = temp;
      dx = parseInt(gs2(temp,"left"))|0;
      dy = parseInt(gs2(temp,"top"))|0;
      x = e.clientX;
      y = e.clientY;
      document.onmousemove = move;
      return false;
     }
    }
    function up(){
     dragok = false;
     document.onmousemove = null;
    }
    document.onmousedown = down;
    document.onmouseup = up;
   }
  )();
 }
 -->
 </script>
</head>
<body>
<div class="dragclass" id="main" style="LEFT: 588px; TOP: 298px">
<div id="ChatHead"><a onclick="ChatHidden();" href="#">-</a>
<a onclick="ChatShow();" href="#">+</a>
<a onclick="ChatClose();" href="#">x</a> </div>
<div id="ChatBody">
<div id="ChatContent">HI! Hello ! Welcome to 3water.com</div>
<div id="ChatBtn">
<form action="" method="post" name="chat">
</form>
</div>
</div>
</div>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
js function定义函数使用心得
Apr 15 Javascript
判断用户是否在线的代码
Mar 05 Javascript
jQuery删除节点的三个方法即remove()detach()和empty()
Dec 27 Javascript
用js正确判断用户名cookie是否存在的方法
Jan 28 Javascript
JS实现漂亮的淡蓝色滑动门效果代码
Sep 23 Javascript
js中substring和substr两者区别和使用方法
Nov 09 Javascript
js的form表单提交url传参数(包含+等特殊字符)的两种解决方法
May 25 Javascript
基于Bootstrap+jQuery.validate实现表单验证
May 30 Javascript
JS动态的把左边列表添加到右边的实现代码(可上下移动)
Nov 17 Javascript
详解bootstrap用dropdown-menu实现上下文菜单
Sep 22 Javascript
Vue无限滑动周选择日期的组件的示例代码
Jul 18 Javascript
jquery实现联想词搜索框和搜索结果分页的示例
Oct 10 jQuery
Javascript中typeof 用法小结
May 12 #Javascript
js/jquery判断浏览器类型的方法小结
May 12 #Javascript
js实现div层缓慢收缩与展开的方法
May 11 #Javascript
JS实现定时自动关闭DIV层提示框的方法
May 11 #Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 #Javascript
JavaScript实现表格点击排序的方法
May 11 #Javascript
JavaScript点击按钮后弹出透明浮动层的方法
May 11 #Javascript
You might like
基于PHP技术开发客服工单系统
2016/01/06 PHP
php设计模式之中介者模式分析【星际争霸游戏案例】
2020/03/23 PHP
用于判断用户注册时,密码强度的JS代码
2009/01/01 Javascript
Array.prototype.slice.apply的使用方法
2010/03/17 Javascript
JQuery中对服务器控件 DropdownList, RadioButtonList, CheckboxList的操作总结
2011/06/28 Javascript
nullJavascript中创建对象的五种方法实例
2013/05/07 Javascript
JS图片无缝滚动(简单利于使用)
2013/06/17 Javascript
new Date()问题在ie8下面的处理方法
2014/07/31 Javascript
JavaScript获取网页表单action属性的方法
2015/04/02 Javascript
jquery实现带缩略图的全屏图片画廊效果实例
2015/06/25 Javascript
jQuery实现图片渐入渐出切换展示效果
2015/08/15 Javascript
JS异步加载的三种实现方式
2017/03/16 Javascript
jQuery实现鼠标响应式淘宝动画效果示例
2018/02/13 jQuery
Bootstrap table表格初始化表格数据的方法
2018/07/25 Javascript
JointJS流程图的绘制方法
2018/12/03 Javascript
Vue路由模块化配置的完整步骤
2019/08/14 Javascript
Element-UI+Vue模式使用总结
2020/01/02 Javascript
[19:14]DOTA2 HEROS教学视频教你分分钟做大人-维萨吉
2014/06/24 DOTA
[40:17]2018DOTA2亚洲邀请赛 4.5 淘汰赛 LGD vs Liquid 第一场
2018/04/06 DOTA
python使用线程封装的一个简单定时器类实例
2015/05/16 Python
Python中有趣在__call__函数
2015/06/21 Python
利用Python进行异常值分析实例代码
2017/12/07 Python
Python docx库用法示例分析
2019/02/16 Python
python利用opencv实现SIFT特征提取与匹配
2020/03/05 Python
HTML5 Notification(桌面提醒)功能使用实例
2014/03/17 HTML / CSS
html5使用canvas压缩图片的示例代码
2018/09/11 HTML / CSS
英国汽车和货车租赁网站:Hertz英国
2016/09/02 全球购物
网络、C以及其他硬件方面的面试题
2016/08/23 面试题
路由表示做什么用的?在linux环境中怎么来配置一条默认路由?
2013/06/07 面试题
电气工程及其自动化学生实习自我鉴定
2013/09/19 职场文书
2014年保管员工作总结
2014/11/18 职场文书
2014年节能减排工作总结
2014/12/06 职场文书
毕业生登记表班级意见
2015/06/05 职场文书
2015选调生工作总结
2015/07/24 职场文书
关于做家务的心得体会
2016/01/23 职场文书
python中Tkinter 窗口之输入框和文本框的实现
2021/04/12 Python