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 相关文章推荐
jQuery对象和DOM对象相互转化
Apr 24 Javascript
jQuery新闻滚动插件 jquery.roller.js
Jun 27 Javascript
JS解析json数据并将json字符串转化为数组的实现方法
Dec 25 Javascript
JavaScript创建类/对象的几种方式概述及实例
May 06 Javascript
js设置cookie过期当前时间减去一秒相当于立即过期
Sep 04 Javascript
IE6浏览器中window.location.href无效的解决方法
Nov 20 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
Sep 20 Javascript
JavaScript表单验证的两种实现方法
Feb 11 Javascript
vue+axios实现登录拦截的实例代码
May 22 Javascript
layui table 表格模板按钮的实例代码
Sep 21 Javascript
javascript异常处理实现原理详解
Feb 17 Javascript
Vue router安装及使用方法解析
Dec 02 Vue.js
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使用memcoder将视频转成mp4格式的方法
2015/03/12 PHP
php实现阳历阴历互转的方法
2015/10/28 PHP
Laravel如何友好的修改.env配置文件详解
2017/06/07 PHP
jQuery中$.fn的用法示例介绍
2013/11/05 Javascript
js拖动div 当鼠标移动时整个div也相应的移动
2013/11/21 Javascript
推荐5 个常用的JavaScript调试技巧
2015/01/08 Javascript
JS实现让网页背景图片斜向移动的方法
2015/02/25 Javascript
JavaScript中的pow()方法使用详解
2015/06/15 Javascript
javascript的变量、传值、传址、参数之间关系
2015/07/26 Javascript
javascript从作用域链谈闭包
2020/07/29 Javascript
JavaScript事件类型中UI事件详解
2016/01/14 Javascript
JavaScript学习笔记之数组的增、删、改、查
2016/03/23 Javascript
Bootstrap三种表单布局的使用方法
2016/06/21 Javascript
Angular.JS利用ng-disabled属性和ng-model实现禁用button效果
2017/04/05 Javascript
小程序实现选择题选择效果
2018/11/04 Javascript
亲自动手实现vue日历控件
2019/06/26 Javascript
JS常用跨域方法实现原理解析
2020/12/09 Javascript
零基础写python爬虫之爬虫框架Scrapy安装配置
2014/11/06 Python
详解Python中的各种函数的使用
2015/05/24 Python
对python 命令的-u参数详解
2018/12/03 Python
15行Python代码实现网易云热门歌单实例教程
2019/03/10 Python
哪种Python框架适合你?简单介绍几种主流Python框架
2020/08/04 Python
Python如何使用input函数获取输入
2020/08/06 Python
可口可乐唇膏:Lip Smackers
2019/08/27 全球购物
高级文秘工作总结的自我评价
2013/09/28 职场文书
揠苗助长教学反思
2014/02/04 职场文书
《音乐之都维也纳》教学反思
2014/04/16 职场文书
初中优秀班集体申报材料
2014/05/01 职场文书
银行先进个人事迹材料
2014/05/11 职场文书
学校节能宣传周活动总结
2014/07/09 职场文书
我爱家乡演讲稿
2014/09/12 职场文书
2015年毕业生实习评语
2015/03/25 职场文书
SQL Server——索引+基于单表的数据插入与简单查询【1】
2021/04/05 SQL Server
使用golang编写一个并发工作队列
2021/05/08 Golang
HTML5之高度塌陷问题的解决
2022/06/01 HTML / CSS
win10+RTX3050ti+TensorFlow+cudn+cudnn配置深度学习环境的方法
2022/06/25 Servers