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实现在同一窗口浏览图片
Sep 17 Javascript
JavaScript对象之深度克隆介绍
Dec 08 Javascript
ECMAScript 5严格模式(Strict Mode)介绍
Mar 02 Javascript
node.js连接mongoDB数据库 快速搭建自己的web服务
Apr 17 Javascript
深入理解jquery中的each用法
Dec 14 Javascript
webpack学习--webpack经典7分钟入门教程
Jun 28 Javascript
vue实现移动端图片裁剪上传功能
Aug 18 Javascript
轻松玩转BootstrapTable(后端使用SpringMVC+Hibernate)
Sep 06 Javascript
JS实现的获取银行卡号归属地及银行卡类型操作示例
Jan 08 Javascript
Vue组件内部实现一个双向数据绑定的实例代码
Apr 04 Javascript
jquery 回调操作实例分析【回调成功与回调失败的情况】
Sep 27 jQuery
vue3不同环境下实现配置代理
May 25 Vue.js
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初学者们头痛的十四个问题
2007/01/15 PHP
php网页标题中文乱码的有效解决方法
2014/03/05 PHP
PHP数组操作――获取数组最后一个值的方法
2015/04/14 PHP
php自动识别文字编码并转换为目标编码的方法
2015/08/08 PHP
php获取远程文件大小
2015/10/20 PHP
PHP编程计算日期间隔天数的方法
2017/04/26 PHP
用javascript实现计算两个日期的间隔天数
2007/08/14 Javascript
javascript 浏览器检测代码精简版
2010/03/04 Javascript
appendChild() 或 insertBefore()使用与区别介绍
2013/10/11 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
2016/09/20 Javascript
微信小程序之获取当前位置经纬度以及地图显示详解
2017/05/09 Javascript
微信小程序图片自适应支持多图实例详解
2017/06/21 Javascript
微信小程序 动态修改页面数据及参数传递过程详解
2019/09/27 Javascript
vuex(vue状态管理)的特殊应用案例分享
2020/03/03 Javascript
JS实现简单移动端鼠标拖拽
2020/07/23 Javascript
基于postman获取动态数据过程详解
2020/09/08 Javascript
[42:39]老党炸弹人试玩视频
2014/09/03 DOTA
[06:11]2014DOTA2国际邀请赛 专访团结一心的VG战队
2014/07/21 DOTA
解决tensorflow模型参数保存和加载的问题
2018/07/26 Python
python查询文件夹下excel的sheet名代码实例
2019/04/02 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
安装Pycharm2019以及配置anconda教程的方法步骤
2019/11/11 Python
python 通过视频url获取视频的宽高方式
2019/12/10 Python
Python基于DB-API操作MySQL数据库过程解析
2020/04/23 Python
Python celery原理及运行流程解析
2020/06/13 Python
python 制作本地应用搜索工具
2021/02/27 Python
html5教程调用绘图api画简单的圆形代码分享
2013/12/04 HTML / CSS
Web时代变迁及html5与html4的区别
2016/01/06 HTML / CSS
amazeui时间组件的实现示例
2020/08/18 HTML / CSS
Ootori在线按摩椅店:一家专业的按摩椅制造商
2019/04/10 全球购物
eharmony澳大利亚:网上约会服务
2020/02/29 全球购物
介绍一下OSI七层模型
2012/07/03 面试题
计算机毕业生自荐信范文
2014/03/23 职场文书
祝福语集锦:送给闺蜜的生日祝福语
2019/10/08 职场文书
Python必备技巧之函数的使用详解
2022/04/04 Python
SQL Server携程核心系统无感迁移到MySQL实战
2022/06/01 SQL Server