javascript event在FF和IE的兼容传参心得(绝对好用)


Posted in Javascript onJuly 10, 2014

event在IE和FF不兼容,今天传参碰到些问题,参考网上的一些方法,有所心得:

aClassArray[i].onmouseover = function () { //代码直接写在里面是可以的,要传参也可以传,只是不方便复用 };

aClassArray[i].onmouseover =linkMouseover//不传参的情况下是可以用的,但后续不能用 arguments.callee.caller.arguments[0]

aClassArray[i].onmouseover =linkMouseover()//加括号是错误用法

aClassArray[i].onmouseover = function () { linkMouseover(this) };//this能传进去,可以alert出来,但evt.clientX + "px"就出问题了,是空的。。。 arguments.callee.caller.arguments[0]//可以用这个解决

var src = evt.srcElement || evt.target; //后续还可以跟src

===========================================================================

附上练习代码

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="stylesheet" href="css/ui-lightness/jquery-ui-1.10.4.custom.css" rel="external nofollow" />
<script src="js/jquery-1.10.2.js"></script>
<script src="js/jquery-ui-1.10.4.custom.js"></script>
<style type="text/css">
.aClass, .aClass:visited {
font-size: 36px;
text-decoration: none;
color: #0094ff;
}


.divTips {
font-size: 20px;
color: red;
border: #f00 1px solid;
position: absolute;
width: 100px;
height: 30px;
}
</style>
<script type="text/javascript">
function initOnOver() {
var titleTips = {
"baidu": "百度网站提示",
"163": "163网站提示",
"google": "google网站提示"
}
var aTag = document.getElementsByTagName("a");
var aClassArray = [];
for (var i = 0; i < aTag.length; i++) {
if (aTag[i].className == "aClass") {
aClassArray[aClassArray.length] = aTag[i];
}
}
for (var i = 0; i < aClassArray.length; i++) {
var e;
aClassArray[i].onmouseover = function () { linkMouseover() };
aClassArray[i].onmouseout = linkMouseout;
}
}
function linkMouseover() {
var divTips = document.createElement("div");
var evt = window.event || arguments.callee.caller.arguments[0]; // 获取event对象
divTips.className = "divTips";
divTips.style.left = evt.clientX + "px";//+px兼容FF
divTips.style.top = evt.clientY + "px";//+px兼容FF
divTips.innerHTML = "test";
document.getElementById("divA").appendChild(divTips);
}
function linkMouseout() {
var divTag = document.getElementsByTagName("div");
for (var i = 0; i < divTag.length; i++) {
if (divTag[i].className == "divTips") {
document.getElementById("divA").removeChild(divTag[i]);
}
}
}
window.onload = initOnOver;
</script>
</head>
<body>
<div id="divA">
<a href="http://www.baidu.com" rel="external nofollow" class="aClass">百度</a>
<br />
<br />
<br />
<a href="http://www.163.com" rel="external nofollow" class="aClass">网易</a>
<br />
<br />
<br />
<a href="http://www.google.com" rel="external nofollow" class="aClass">Google</a>
</div>
</body>
</html>
Javascript 相关文章推荐
COM中获取JavaScript数组大小的代码
Nov 22 Javascript
jQuery中$.ajax()和$.getJson()同步处理详解
Aug 12 Javascript
js 判断数据类型的几种方法
Jan 13 Javascript
微信小程序 数据遍历的实现
Apr 05 Javascript
js按条件生成随机json:randomjson实现方法
Apr 07 Javascript
老生常谈jacascript DOM节点获取
Apr 17 Javascript
解决Vue打包之后文件路径出错的问题
Mar 06 Javascript
Javascript的this详解
Mar 23 Javascript
js时间转换毫秒的实例代码
Aug 21 Javascript
vue封装可复用组件confirm,并绑定在vue原型上的示例
Oct 31 Javascript
Postman如何实现参数化执行及断言处理
Jul 28 Javascript
Vue两种组件类型:递归组件和动态组件的用法
Aug 06 Javascript
js确认删除对话框适用于a标签及submit
Jul 10 #Javascript
JQuery1.8 判断元素是否绑定事件的方法
Jul 10 #Javascript
jquery实现类似EasyUI的页面布局可改变左右的宽度
Sep 12 #Javascript
借助JavaScript脚本判断浏览器Flash Player信息的方法
Jul 09 #Javascript
jQuery获取选中内容及设置元素属性的方法
Jul 09 #Javascript
js数组与字符串的相互转换方法
Jul 09 #Javascript
在Linux上用forever实现Node.js项目自启动
Jul 09 #Javascript
You might like
解析php dirname()与__FILE__常量的应用
2013/06/24 PHP
关于使用key/value数据库redis和TTSERVER的心得体会
2013/06/28 PHP
shell脚本作为保证PHP脚本不挂掉的守护进程实例分享
2013/07/15 PHP
推荐十款免费 WordPress 插件
2015/03/24 PHP
php实现的Curl封装类Curl.class.php用法实例分析
2015/09/25 PHP
php微信开发之上传临时素材
2016/06/24 PHP
jQuery EasyUI 中文API Button使用实例
2010/04/14 Javascript
JavaScript中的onerror事件概述及使用
2013/04/01 Javascript
jQuery实现感应鼠标动画效果自动伸长的输入框实例
2015/02/24 Javascript
javascript文件加载管理简单实现方法
2015/07/25 Javascript
使用js复制链接中的部分文字的方法
2015/07/30 Javascript
学习JavaScript设计模式之单例模式
2016/01/19 Javascript
js获取当前日期时间及其它日期操作汇总
2016/03/08 Javascript
设置jQueryUI DatePicker默认语言为中文
2016/06/04 Javascript
JavaScript禁止用户多次提交的两种方法
2016/07/24 Javascript
微信小程序 wx.uploadFile在安卓手机上面the same task is working问题解决
2016/12/14 Javascript
利用Node.js了解与测量HTTP所花费的时间详解
2017/09/22 Javascript
vue中Npm run build 根据环境传递参数方法来打包不同域名
2018/03/29 Javascript
基于vue-router 多级路由redirect 重定向的问题
2018/09/03 Javascript
详解vue数组遍历方法forEach和map的原理解析和实际应用
2018/11/15 Javascript
JS实现鼠标拖拽盒子移动及右键点击盒子消失效果示例
2019/01/29 Javascript
vue学习笔记之作用域插槽实例分析
2020/02/01 Javascript
[02:42]岂曰无衣,与子同袍!DOTA2致敬每一位守护人
2020/02/17 DOTA
实例讲解Python中global语句下全局变量的值的修改
2016/06/16 Python
Flask框架响应、调度方法和蓝图操作实例分析
2018/07/24 Python
详解如何为eclipse安装合适版本的python插件pydev
2018/11/04 Python
python实现简单日期工具类
2019/04/24 Python
Python可以实现栈的结构吗
2020/05/27 Python
美国顶级品牌男士大码服装店:DXL
2017/08/30 全球购物
住房公积金接收函
2014/01/09 职场文书
2015年数学教研组工作总结
2015/05/23 职场文书
跑出一片天观后感
2015/06/08 职场文书
2015军训通讯稿大全
2015/07/18 职场文书
《海上日出》教学反思
2016/02/23 职场文书
position:sticky 粘性定位的几种巧妙应用详解
2021/04/24 HTML / CSS
Python作用域和名称空间的详细介绍
2022/04/13 Python