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 相关文章推荐
asp批量修改记录的代码
Jun 25 Javascript
JS 实现双色表格实现代码
Nov 24 Javascript
json的定义、标准格式及json字符串检验
May 11 Javascript
谷歌地图打不开的解决办法
Aug 07 Javascript
[将免费进行到底]在Amazon的一年免费服务器上安装Node.JS, NPM和OurJS博客
Aug 18 Javascript
基于javascript实现窗口抖动效果
Jan 03 Javascript
浅谈jQuery双事件多重加载的问题
Oct 05 Javascript
JavaScript算法教程之sku(库存量单位)详解
Jun 29 Javascript
Vue.js 单页面多路由区域操作的实例详解
Jul 17 Javascript
jQuery实现上传图片前预览效果功能
Aug 03 jQuery
clipboard.js在移动端复制失败的解决方法
Jun 13 Javascript
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析
May 22 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转成EXE文件
2006/10/09 PHP
从C/C++迁移到PHP——判断字符类型的函数
2006/10/09 PHP
PHP开发的一些注意点总结
2010/10/12 PHP
php文件上传表单摘自drupal的代码
2011/02/15 PHP
YII路径的用法总结
2014/07/09 PHP
PHP如何通过传引用的思想实现无限分类(代码简单)
2015/10/13 PHP
WordPress 照片lightbox效果的运用几点
2009/06/22 Javascript
Notify - 基于jquery的消息通知插件
2011/10/18 Javascript
javascript重写alert方法的实例代码
2013/03/29 Javascript
JS测试显示屏分辨率以及屏幕尺寸的方法
2013/11/22 Javascript
jQuery表单域选择器用法分析
2015/02/10 Javascript
详解jQuery中的元素的属性和相关操作
2015/08/14 Javascript
jQuery实现的调整表格行tr上下顺序
2016/01/10 Javascript
浅谈JavaScript 执行环境、作用域及垃圾回收
2016/05/31 Javascript
javascript中的深复制详解及实例分析
2016/12/29 Javascript
JavaScript自执行函数和jQuery扩展方法详解
2017/10/27 jQuery
详解node child_process模块学习笔记
2018/01/24 Javascript
antd vue table跨行合并单元格,并且自定义内容实例
2020/10/28 Javascript
[04:53]DOTA2英雄基础教程 祈求者
2014/01/03 DOTA
python中的多重继承实例讲解
2014/09/28 Python
使用tensorflow实现线性回归
2018/09/08 Python
在Python中构建增广矩阵的实现方法
2019/07/01 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
python 接口实现 供第三方调用的例子
2019/08/13 Python
使用python写一个自动浏览文章的脚本实例
2019/12/05 Python
Django 实现图片上传和下载功能
2020/12/31 Python
英语专业学生个人求职信范文
2014/01/06 职场文书
公司聘任书模板
2014/03/29 职场文书
综艺节目策划方案
2014/06/13 职场文书
工作能力自我评价2015
2015/03/05 职场文书
2015年文员个人工作总结
2015/04/09 职场文书
教师继续教育反思周记
2015/06/25 职场文书
聘任书范文大全
2015/09/21 职场文书
pytorch中的model.eval()和BN层的使用
2021/05/22 Python
详解Python如何批量采集京东商品数据流程
2022/01/22 Python
分享几个实用的CSS代码块
2022/06/10 HTML / CSS