Js获取事件对象代码
更新时间:2010年08月05日 03:30:31 作者:
js下比较实用的事件绑定代码,学习js 的朋友一定要学习的,为你的页面增加更好的交互。
一般做法:
<input type="button" id="test" value="点我测试" />
<script type="text/javascript">
var testBtn = document.getElementById('test');
testBtn.onclick = testFun;
function testFun(e)
{
var evt = e || window.event;
alert(evt);
}
</script>
或者:
<input type="button" id="test" value="点我测试" />
<script type="text/javascript">
var testBtn = document.getElementById('test');
if(window.addEventListener)
{
testBtn.addEventListener('click', testFun, false);
}
else if(window.attachEvent)
{
testBtn.attachEvent('onclick', testFun);
}
function testFun(e)
{
var evt = e || window.event;
alert(evt);
}
</script>
返回的值都是 “[object Event]“。
但如果是这种方式呢?
<input type="button" id="test_1" value="点我测试" onclick="testFun_1()" />
<script type="text/javascript">
function testFun_1()
{
//此处如何获得?
}
</script>
“内事不决问百度,外事不决问谷歌”, 此言不虚。搜索了下,答案还真不少,不过大多数雷同(可能是巧合)。
https://www.jb51.net/article/19408.htm
http://www.cnblogs.com/cuixiping/archive/2008/04/13/1150847.html
愚公 的这个文章(貌似转帖)还是颇有见解的。
<input type="button" id="test_1" value="点我测试" onclick="testFun_1()" />
<script type="text/javascript">
function testFun_1()
{
var evt = getEvent();
alert(evt);
}
function getEvent(){
if(window.event) return window.event; //这里用对象检测更为妥当
func=getEvent.caller;
while(func!=null){
var arg0=func.arguments[0];
if(arg0){
if((arg0.constructor==Event || arg0.constructor ==MouseEvent)
|| (typeof(arg0)=="object" && arg0.preventDefault && arg0.stopPropagation)){
return arg0;
}
}
func=func.caller;
}
return null;
}
</script>
一般来说,很少用到这种嵌入式的写法(js写在html标签中 onclick="testFun_1()"),也不推荐使用这种方法,会造成维护和开发的麻烦。
复制代码 代码如下:
<input type="button" id="test" value="点我测试" />
<script type="text/javascript">
var testBtn = document.getElementById('test');
testBtn.onclick = testFun;
function testFun(e)
{
var evt = e || window.event;
alert(evt);
}
</script>
或者:
复制代码 代码如下:
<input type="button" id="test" value="点我测试" />
<script type="text/javascript">
var testBtn = document.getElementById('test');
if(window.addEventListener)
{
testBtn.addEventListener('click', testFun, false);
}
else if(window.attachEvent)
{
testBtn.attachEvent('onclick', testFun);
}
function testFun(e)
{
var evt = e || window.event;
alert(evt);
}
</script>
返回的值都是 “[object Event]“。
但如果是这种方式呢?
复制代码 代码如下:
<input type="button" id="test_1" value="点我测试" onclick="testFun_1()" />
<script type="text/javascript">
function testFun_1()
{
//此处如何获得?
}
</script>
“内事不决问百度,外事不决问谷歌”, 此言不虚。搜索了下,答案还真不少,不过大多数雷同(可能是巧合)。
https://www.jb51.net/article/19408.htm
http://www.cnblogs.com/cuixiping/archive/2008/04/13/1150847.html
愚公 的这个文章(貌似转帖)还是颇有见解的。
复制代码 代码如下:
<input type="button" id="test_1" value="点我测试" onclick="testFun_1()" />
<script type="text/javascript">
function testFun_1()
{
var evt = getEvent();
alert(evt);
}
function getEvent(){
if(window.event) return window.event; //这里用对象检测更为妥当
func=getEvent.caller;
while(func!=null){
var arg0=func.arguments[0];
if(arg0){
if((arg0.constructor==Event || arg0.constructor ==MouseEvent)
|| (typeof(arg0)=="object" && arg0.preventDefault && arg0.stopPropagation)){
return arg0;
}
}
func=func.caller;
}
return null;
}
</script>
一般来说,很少用到这种嵌入式的写法(js写在html标签中 onclick="testFun_1()"),也不推荐使用这种方法,会造成维护和开发的麻烦。
您可能感兴趣的文章:
- javascript的offset、client、scroll使用方法详解
- js中top、clientTop、scrollTop、offsetTop的区别 文字详细说明版
- js中的scroll和offset 使用比较的实例与分析
- javascript scrollLeft,scrollWidth,clientWidth,offsetWidth 完全详解
- javascript中offset、client、scroll的属性总结
- js之事件冒泡和事件捕获详细介绍
- 阻止JavaScript事件冒泡传递(cancelBubble 、stopPropagation)
- javascript事件冒泡详解和捕获、阻止方法
- js中获取事件对象的方法小结
- JS的Event事件对象使用方法
- JS前端知识点offset,scroll,client,冒泡,事件对象的应用整理总结
相关文章
bootstrap响应式导航条模板使用详解(含下拉菜单,弹出框)
这篇文章主要为大家详细介绍了bootstrap响应式导航条模板使用详解,含下拉菜单,弹出框效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11
最新评论