zoukankan      html  css  js  c++  java
  • js事件监听-addEventListener (w3c标准) 和 attachEvent(ie)

    研究了一个小时,没看懂这两个属性

    window.onload = function(){
    var oDiv = document.getElementById("J_myDiv"); //找到对象
    oDiv.onclick = function(){ //设置事件监听函数
    alert("click");
    }
    }

    缺点:1.添加单一事件

            2.不能删除事件

    第二:IE中监听函数

    复制代码
    var oDiv;

    function fnClick(){
    alert("click me");
    oDiv.detachEvent("onclick",fnClick);//删除监听函数
    }

    window.onload = function(){
    oDiv = document.getElementById("J_myDiv");//找到对象
    oDiv.attachEvent("onclick",fnClick); //添加监听函数
    }
    复制代码

    第三:标准DOM监听函数

    复制代码
    var oDiv;

    function fnClick1(){
    alert("click1");
    // oDiv.removeEventListener("click",fnClick2,false); //删除监听函数2
    }

    function fnClick2(){
    alert("click2");
    }

    window.onload = function(){

    oDiv = document.getElementById("J_myDiv"); //找到对象
    oDiv.addEventListener("click",fnClick1,false); //添加监听函数1
    oDiv.addEventListener("click",fnClick2,false); //添加监听函数2

    }
    复制代码


    第四:从js实例来看事件监听 参看:http://imethan.com/?p=208

    第五:从实例来看JS的事件监听学习笔记(事件监听绑定、ff/IE不同的处理机制兼容总结)参看:http://hi.baidu.com/dou917/blog/item/40219f37e6e3deee1b4cff67.html

    第六:代码总结

    复制代码
    <script language="javascript">
    //Javascript 事件演示
    window.onload = function(){
    var hideBox = function(event){
    document.getElementById('status_show').style.display = 'none';
    document.getElementById('status_hide').style.display = 'block';
    };
    var showBox = function(event){
    document.getElementById('status_show').style.display = 'block';
    document.getElementById('status_hide').style.display = 'none';
    stopEvent(event);
    };
    var stopEvent = function(event){
    e = event || window.event;
    if(e.stopPropagation){
    e.stopPropagation();
    }else {
    e.cancelBubble = true;
    }
    };
    if(document.addEventListener){
    document.addEventListener('click', hideBox, false);
    document.getElementById('status_hide').addEventListener('click', showBox, false);
    document.getElementById('status_show').addEventListener('click', stopEvent, false);
    }else {
    //For IE
    document.attachEvent('onclick', hideBox);
    document.getElementById('status_hide').attachEvent('onclick', showBox);
    document.getElementById('status_show').attachEvent('onclick', stopEvent, showBox);
    }
    };
    </script>
  • 相关阅读:
    Camel routes in Spring config file
    Construct a basic automation test framework
    Java custom annotations
    Java Abstract Class
    Hibernate之mappedBy
    hibernate FetchType理解
    hibernate 双向 OneToOne fetchType lazy 问题
    日常总结
    hibernate二级缓存
    sql子查询和嵌套查询
  • 原文地址:https://www.cnblogs.com/jquery37/p/4645079.html
Copyright © 2011-2022 走看看