• 如何解决firefox下window.event的问题


    一、在函数中传递event参数

        在函数中传递event参数,这样我们就可以兼容IE和FF的event的获取了,如下面的函数:

    function _test(evt)
    {
        var src = evt.srcElement || evt.target; // 获取触发事件的源对象
        alert(src.value); // 打印该对象的value属性
    }

        那么我们在使用的时候就应该这样:

    <input type='button' value='click me' onclick='_test(event)' />

    二、在函数调用中不传递event对象

        虽然在函数中没有传递参数,这个在IE下没有任何影响,因为window.event是全局对象,在什么地方都可以直接调用的,而在FF下就不行了。所以我们这里要使用另外一种方式来获取了,如下:

    function _test2()
    {
        var evt = window.event || arguments.callee.caller.arguments[0]; // 获取event对象
        var src = evt.srcElement || evt.target; // 获取触发事件的源对象
        alert(src.value); // 打印该对象的value属性
    }

        那么,我们在使用的时候就可以想普通的函数调用一样,直接输入函数名称即可,如下:

    <input type='button' value='click me2' onclick='_test2()' />

        可见,相比两种方法,第二种方法更具有普遍和通用性,因为可以不用传递参数了,这样在使用的时候也更加的方便;第一种方式就更加直接明了,呵呵,至于具体怎么用,还得看个人的了~~

  • 相关阅读:
    JavaScript 高级
    JavaScript 归纳
    完全二叉树, 最大堆 , 堆排序
    二叉树
    Java秒杀系统方案优化 高性能高并发实战(1)
    精选 SQL 脚本
    树形结构有关的SQL
    在Sql server数据库中,关于触发器的创建、调用及删除
    SQLServer 唯一键约束和唯一索引有什么区别?
    很不错的 VBA 网址
  • 原文地址:https://www.cnblogs.com/zhuyongblogs/p/5160368.html
Copyright © 2020-2023  润新知