firefox浏览器下javascript 拖动层效果与原理分析代码


Posted in Javascript onDecember 04, 2007

前言

本文主要给大家介绍了关于firefox下js实现拖动层效果的方法,下面话不多说了,来一起看看详细的介绍吧。

firefox下实现可拖动层代码

<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>3water.com 拖动层效果代码</title> 
<script> 
 var obj=0; 
 var x=0; 
 var y=0; 
 var ie = (navigator.appVersion.indexOf("MSIE")!=-1);//IE 
 var ff = (navigator.userAgent.indexOf("Firefox")!=-1);//Firefox 
 function find(evt,objDiv){ 
 obj = objDiv 
 if (ff){ 
  x = document.documentElement.scrollLeft + evt.layerX; 
  y = document.documentElement.scrollTop + evt.layerY; 
   
  if (document.documentElement.scrollTop > 0){ 
   y = evt.layerY - document.documentElement.scrollTop; 
  } 
   
  if (document.documentElement.scrollLeft > 0){ 
   x = evt.layerX - document.documentElement.scrollLeft; 
  } 
  } 
 if (ie){ 
  x = document.documentElement.scrollLeft + evt.offsetX; 
  y = document.documentElement.scrollTop + evt.offsetY; 
   
  if (document.documentElement.scrollTop > 0){ 
   y = evt.offsetY - document.documentElement.scrollTop; 
  } 
   
  if (document.documentElement.scrollLeft > 0){ 
   x = evt.offsetX - document.documentElement.scrollLeft; 
  } 
  } 
 } 
 function dragit(evt){ 
 if(obj == 0){ 
  return false 
 } 
 else{ 
  obj.style.left = evt.clientX - x + "px"; 
  obj.style.top = evt.clientY - y + "px"; 
 } 
 } 
</script> 
</head> 
<body style="margin:0" onmousemove="dragit(event)" onmouseup="obj = 0"> 

<div id="aaa" style="background-color:red;width:200pt;height:200pt;position:absolute"> 
<div id="aa" style="width:200pt;height:20pt;background:blue;position:absolute" onmousedown="find(event,document.getElementById('aaa'))"></div> 
</div><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR><BR> 
</body> 
</html>

JavaScript 中一些概念理解 :clientX、clientY、offsetX、offsetY、screenX、screenY

clientX 设置或获取鼠标指针位置相对于窗口客户区域的 x 坐标,其中客户区域不包括窗口自身的控件和滚动条。

clientY 设置或获取鼠标指针位置相对于窗口客户区域的 y 坐标,其中客户区域不包括窗口自身的控件和滚动条。

offsetX 设置或获取鼠标指针位置相对于触发事件的(this)对象的 x 坐标。

offsetY 设置或获取鼠标指针位置相对于触发事件的(this)对象的 y 坐标。

screenX 设置或获取获取鼠标指针位置相对于用户屏幕的 x 坐标。

screenY 设置或获取鼠标指针位置相对于用户屏幕的 y 坐标。

x 设置或获取鼠标指针位置相对于父文档的 x 像素坐标。

y 设置或获取鼠标指针位置相对于父文档的 y 像素坐标。

如图:图片来源于网络

firefox浏览器下javascript 拖动层效果与原理分析代码

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
关于jQuery中.attr()和.prop()的问题探讨
Sep 06 Javascript
js+csss实现的一个带复选框的下拉框
Sep 29 Javascript
JavaScript中的迭代器和生成器详解
Oct 29 Javascript
jQuery取得iframe中元素的常用方法详解
Jan 14 Javascript
JavaScript对象数组如何按指定属性和排序方向进行排序
Jun 15 Javascript
JavaScript函数绑定用法实例分析
Nov 14 Javascript
Node.js中DNS模块学习总结
Feb 28 Javascript
JQuery Ajax动态加载Table数据的实例讲解
Aug 09 jQuery
vue使用echarts图表的详细方法
Oct 22 Javascript
深入解析koa之中间件流程控制
Jun 17 Javascript
vue实现匀速轮播效果
Jun 29 Javascript
vue实现div单选多选功能
Jul 16 Javascript
超棒的javascript页面顶部卷动广告效果
Dec 01 #Javascript
js同时按下两个方向键
Dec 01 #Javascript
document.documentElement &amp;&amp; document.documentElement.scrollTop
Dec 01 #Javascript
jquery api参考 visualjquery 中国线路 速度快
Nov 30 #Javascript
发布一个高效的JavaScript分析、压缩工具 JavaScript Analyser
Nov 30 #Javascript
jquery 指南/入门基础
Nov 30 #Javascript
Prototype1.6 JS 官方下载地址
Nov 30 #Javascript
You might like
浅谈PHP中的面向对象OOP中的魔术方法
2017/06/12 PHP
TP - 比RBAC更好的权限认证方式(Auth类认证)
2021/03/09 PHP
用js自动判断浏览器分辨率的代码
2007/01/28 Javascript
javascript数组遍历for与for in区别详解
2014/12/04 Javascript
jQuery控制frames及frame页面JS的方法
2016/03/08 Javascript
JavaScript实现Java中Map容器的方法
2016/10/09 Javascript
JavaScript 限制文本框不可输入英文单双引号的方法
2016/12/20 Javascript
javascript实现二叉树的代码
2017/06/08 Javascript
详解vue.js下引入百度地图jsApi的两种方法
2018/07/27 Javascript
微信小程序自定义音乐进度条的实例代码
2018/08/28 Javascript
vue全局使用axios的方法实例详解
2018/11/22 Javascript
vue cli3适配所有端方案的实现
2020/04/13 Javascript
js数组中去除重复值的几种方法
2020/08/03 Javascript
axios封装与传参示例详解
2020/10/18 Javascript
python实现发送和获取手机短信验证码
2016/01/15 Python
python如果快速判断数字奇数偶数
2019/11/13 Python
Python 日期的转换及计算的具体使用详解
2020/01/16 Python
Tensorflow不支持AVX2指令集的解决方法
2020/02/03 Python
快速解决jupyter notebook启动需要密码的问题
2020/04/21 Python
通过Python扫描代码关键字并进行预警的实现方法
2020/05/24 Python
HTML5操作WebSQL数据库的实例代码
2017/08/26 HTML / CSS
html5+css如何实现中间大两头小的轮播效果
2018/12/06 HTML / CSS
阿迪达斯加拿大官网:Adidas加拿大
2016/08/25 全球购物
澳大利亚最好的在线时尚精品店:Princess Polly
2018/01/03 全球购物
Expedia西班牙:预订酒店、机票、旅行和廉价度假套餐
2019/04/10 全球购物
写给老师的表扬信
2014/01/21 职场文书
转预备党员政审材料
2014/02/06 职场文书
企业道德讲堂实施方案
2014/03/19 职场文书
组工干部对照检查材料
2014/08/25 职场文书
不遵守课堂纪律的检讨书
2014/09/24 职场文书
县长“四风”对照检查材料思想汇报
2014/10/05 职场文书
法人单位授权委托书范文
2014/10/06 职场文书
个人简历求职信范文
2015/03/20 职场文书
张丽莉观后感
2015/06/16 职场文书
解决Navicat for Mysql连接报错1251的问题(连接失败)
2021/05/27 MySQL