zoukankan      html  css  js  c++  java
  • JS里面的DOME

    一、JS中的DOM0事件模型
          1、内容模型:直接将函数名作为HTML标签的某个事件属性的属性值;
                    例  rg:<button onlick="func()">按钮</button>

          2、脚本模型:在JS脚本中通过事件属性进行绑定 ;

                  例 eg:window.onlead = function(){}
        但是它也有局限性即:同一个节点只能绑定一个同类型事件

    二、JS中的DOM2事件模型
         1、添加事件绑定:btn1.addEvent("onlick"函数)
            其他浏览器:btn1btn1.addEventListener("click"函数 ,true/false);
            参数三:false(默认);表示事件冒泡,true:表示事件捕获
              兼容写法:if(btn1btn1.addchEvent){
                          btn1.btn1.addchEvent
                        }else{
                           btn1.btn1.addEventListener()
                       }
         优点:同意节点,可以添加多个同类型事件的监听器

         2、取消事件绑定:
           注: 如果取消事件绑定,那么在绑定事件时,回调函数必须使用有名函数,二不能使用匿名函数,
            因为在取消事件绑定时,需传入函数名
                removeEventListener(“click,函数名)     detachEvent("onclick"函数名)
         3、阻断事件冒泡 :
            (1)  IE浏览器中将e.canceBubble属性设为true
                       其他浏览器:调用e.stopPropagetion();方法
                       兼容写法:function myParagraphEventHandler(e) {
                           e = e || window.event;
                            if (e.stopPropagation) {
                            e.stopPropagation(); //IE以外 
                            } else {
                          e.cancelBubble = true; //IE 
                               }
                        }
           (2) 阻止默认事件:


                    IE浏览器中:将e.returnValue属性设为false;
                    其他浏览器:调用e.preventDefault();方法
                    兼容写法:function eventHandler(e) {
                          e = e || window.event;
                    防止默认行为 
                         if (e.preventDefault) {
                              e.preventDefault(); //IE以外 
                      } else {
                            e.returnValue = false; //IE  
                           }
                     }
                 

    三、JS中的事件流 


       1、元素冒泡:当某DOM元素触发 某事件是时  会从当前DOM元素开始,逐个触发其祖先元素的同类事件,指导DOM根节点
                  DOM模型  均为冒泡事件
                 IE中使用,attachEvent()添加的事件  均为冒泡;
                 其他浏览器,.addEventListener添加事件 ,当三个事件参数为false时  为冒泡
      2、事件捕获 :当某DOM元素触发某事件时,会从DOM根节点开始,逐个触发其祖先元素的同类型事件,知道触发到当前元素为止

                 只能使用.addEventListener添加事件,并设置四三个参数为ture时,才能进行捕获当前元素
        
                 注:冒泡事件:当前元素--->根节点                                  捕获事件:根节点--->当前元素
        

  • 相关阅读:
    html5 canvas ( 画一个五角星 ) lineJoin miterLimit
    html5 canvas ( 线段端点的样式 ) lineCap
    html5 canvas ( 矩形的绘制 ) rect, strokeRect, fillRect
    html5 canvas ( 填充图形的绘制 ) closePath, fillStyle, fill
    html5 canvas ( 线段的绘制 ) beginPath, moveTo, strokeStyle, stroke
    c#.net 实现多图上传
    html 浏览器接收的常用 content-type
    node 使用 fs, url, http 模块,组合成小型的服务器 ( 满足html请求, get, post 传值 )
    java servlet 接收上传的文件(commons-fileupload, commons-io)
    java 读取 properties 资源文件
  • 原文地址:https://www.cnblogs.com/zw874827903/p/6720027.html
Copyright © 2011-2022 走看看