• JavaScript绑定事件的方法[3种]


    在JavaScript中,有三种常用的绑定事件的方法:

    1. 在DOM元素中直接绑定;
    2. 在JavaScript代码中绑定;
    3. 绑定事件监听函数。

    一. 在DOM元素中直接绑定

    这里的DOM元素,可以理解为HTML标签。JavaScript支持在标签中直接绑定事件,语法为:
        onXXX="JavaScript Code"

    其中:

    • onXXX 为事件名称。例如,鼠标单击事件 onclick ,鼠标双击事件 ondouble,鼠标移入事件 onmouseover,鼠标移出事件 onmouseout 等。
    • JavaScript Code 为处理事件的JavaScript代码,一般是函数。


    例如,单击一个按钮,弹出警告框的代码有如下两种写法。

    <input  onclick="alert('谢谢支持')"  type="button"  value="点击我,弹出警告框" />

    <input  onclick="myAlert()"  type="button"  value="点击我,弹出警告框" />
    <script type="text/javascript">
    function myAlert(){
        alert("谢谢支持");
    }
    </script>

    二. 在JavaScript代码中绑定

    在JavaScript代码中(即<script>标签内)绑定事件可以使JavaScript代码与HTML标签分离,文档结构清晰,便于管理和开发。

    在JavaScript代码中绑定事件的语法为:
    elementObject.onXXX=function(){
        // 事件处理代码
    }
    其中:
      • elementObject 为DOM对象,即DOM元素。
      • onXXX 为事件名称。
      • 例如,为 id="demo" 的按钮绑定一个事件,显示它的 type 属性:
    <input  id="demo"  type="button"  value="点击我,显示 type 属性" />
    <script type="text/javascript">
    document.getElementById("demo").onclick=function(){
        alert(this.getAttribute("type"));  //  this 指当前发生事件的HTML元素,这里是<div>标签
    }
    </script>

    三. 绑定事件监听函数

    绑定事件的另一种方法是用 addEventListener() 或 attachEvent() 来绑定事件监听函数。

    addEventListener()函数语法:
    elementObject.addEventListener(eventName,handle,useCapture);
    参数说明
    elementObject DOM对象(即DOM元素)。
    eventName 事件名称。注意,这里的事件名称没有“ on ”,如鼠标单击事件 click ,鼠标双击事件 doubleclick ,鼠标移入事件 mouseover,鼠标移出事件 mouseout 等。
    handle 事件句柄函数,即用来处理事件的函数。
    useCapture Boolean类型,是否使用捕获,一般用false 。这里涉及到JavaScript事件流的概念,后续章节将会详细讲解。
    
    
    attachEvent()函数语法:
    elementObject.attachEvent(eventName,handle);
    参数说明
    elementObject DOM对象(即DOM元素)。
    eventName 事件名称。注意,与addEventListener()不同,这里的事件名称有“ on ”,如鼠标单击事件 onclick ,鼠标双击事件 ondoubleclick ,鼠标移入事件 onmouseover,鼠标移出事件 onmouseout 等。
    handle 事件句柄函数,即用来处理事件的函数。
    
    
    注意:事件句柄函数是指“ 函数名 ”,不能带小括号。

    addEventListener()是标准的绑定事件监听函数的方法,是W3C所支持 的,Chrome、FireFox、Opera、Safari、IE9.0及其以上版本都支持该函数;但是,IE8.0及其以下版本不支持该方法,它使用 attachEvent()来绑定事件监听函数。所以,这种绑定事件的方法必须要处理浏览器兼容问题。

    下面绑定事件的代码,进行了兼容性处理,能够被所有浏览器支持:
    function addEvent(obj,type,handle){
        try{  // Chrome、FireFox、Opera、Safari、IE9.0及其以上版本
            obj.addEventListener(type,handle,false);
        }catch(e){
            try{  // IE8.0及其以下版本
                obj.attachEvent('on' + type,handle);
            }catch(e){  // 早期浏览器
                obj['on' + type] = handle;
            }
        }
    }

    这里使用 try{ ... } catch(e){ ... } 代替 if ... else... 语句,避免浏览器出现错误提示。 例如,为一个 id="demo" 的按钮绑定事件,鼠标单击时弹出警告框
    addEvent(document.getElementById("demo"),"click",myAlert);
    function myAlert(){
    alert("又是一个警告框");
    }
    
    
    

      

  • 相关阅读:
    现有某电商网站用户对商品的收藏数据,记录了用户收藏的商品id以及收藏日期,名为buyer_favorite1。 buyer_favorite1包含:买家id,商品id,收藏日期这三个字段,数据以“ ”分割
    面向对象程序设计中类与类的关系都有哪几种?分别用类图实例说明。
    Java为什么没有指针
    touchz,mkdir,vi的区别
    session使用方法
    迪杰斯特拉算法-文档读取数据
    数据结构---公交线路提示系统(Java后台+excel表格+web前端)
    caffe中train过程的train数据集、val数据集、test时候的test数据集区别
    caffe程序中出现的db.cpp:#line(行号) unknown database backend问题
    caffe的cancat层
  • 原文地址:https://www.cnblogs.com/jiangzhengbin/p/5684450.html
Copyright © 2020-2023  润新知