JS与JQ绑定事件的几种方式

JS绑定事件的三种方式

直接在DOM中进行绑定

<button onclick="alert('success')" type="button" id="btn">测试按钮</button>

DOM中绑定函数名

  <button onclick="testFun" type="button" id="btn">测试按钮</button>
<script>
function testFun() {
alert('sucess')
}
</script>

使用on+事件名绑定

    var btn = document.getElementById('btn')
btn.onclick = function () {
alert('成功')
}

使用事件监听绑定

  • 此方法需要考虑兼容性.
  • 非IE: element.addEventListener(type, handler, false)
  • IE: element.attachEvent('on' + type, handler)
  <script>
var btn = document.getElementById('btn')
if (btn.addEventListener) {
btn.addEventListener('click', function () {
alert('成功')
}, false)
} else {
btn.attachEvent('onclick', function () {
alert('成功')
})
}
</script>

区别

  • 前两种就不再说了, 感觉现在Vue框架事件绑定方式类似于第二种
  • 事件监听的方式的优势在于, 可以为同一个事件绑定多个方法.
  • 如果是第一个进行绑定多个方法的话, 会把函数替换掉, 没有办法绑定多次.

jQuery的几种事件绑定方式

  • jQuery提供了四种绑定方式: bind、live、delegate、on
  • 对应接触事件的四种方式: unbind、die、undelegate、off

bind:

  • 使用频率较高的一种, 作用是在选择到的元素上绑定特定事件类型的监听函数.
element.bind(types, data, fn)
  • 参数含义:

    • type: 事件类型, 如: click、change、mouseover
    • data: [可选],传入监听函数的参数, 通过event.data取到.
    • fn: 监听函数. 可以传入event对象, 但是这里的event对象是jq封装的对象, 与原生有区别
// bind源码
bind: function( types, data, fn ) {
return this.on( types, null, data, fn );
}
  • bind的特点是吧监听器绑定到目标元素上, 但无法形成动态绑定, 需要再次bind
  • live可以对目标元素形成动态绑定.
  • 如果有再次添加的元素, 需要再次使用bind进行添加.

live

  • 并没有把事件绑定到自己身上, 而是绑定到了顶级的父元素document上.
// 源码
live: function( types, data, fn ) {
jQuery( this.context ).on( types, this.selector, data, fn );
return this;
}
  • 通常情况下, 这个context指的是document
  • 但在这种情况下document会变得非常重.

delegate

  • 将事件绑定在就近的元素上
delegate: function( selector, types, data, fn ) {
return this.on( types, selector, data, fn );
}
  • delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。
// button 是在div中的一个标签.
$("div").delegate("button","click",function(){
$("p").slideToggle();
});

on

  • 其实所有的方法都是调用的on这个方法.
on(type, [selector], [data], fn)
  • 使用on绑定可以极大的节省效率.
  • 使用on可以完成所有方法的绑定.
  • on里面的代码量很大.
  • 最后一个参数 one 没有搞明白.

JS与JQ绑定事件的几种方式.的更多相关文章

  1. jq绑定事件的4种方式

    jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码.下面我们来看下jQuery中绑定事件的方式都有哪 ...

  2. 为input标签绑定事件的几种方式

    为input标签绑定事件的几种方式 1.JavaScript原生态的方式,直接复制下面的代码就会有相应的效果 <!DOCTYPE html><html><head> ...

  3. Android_安卓为按钮控件绑定事件的五种方式

    一.写在最前面 本次,来介绍一下安卓中为控件--Button绑定事件的五种方式. 二.具体的实现 第一种:直接绑定在Button控件上: 步骤1.在Button控件上设置android:onClick ...

  4. jQuery绑定事件的四种方式:bind、live、delegate、on

    1.jQuery操作DOM元素的绑定事件的四种方式 jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undele ...

  5. GIS-ArcGIS JS API FeatureLayer图层绑定事件的几种方式

    一.以下四种方式均可以 importantProvinceLayer.on("click", DoIdentify); dojo.connect(importantProvince ...

  6. jQuery绑定事件的四种方式

      jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码.下面我们来看下jQuery中绑定事件的方式都 ...

  7. jQuery绑定事件的四种方式区别

    jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off.在开始看他们之前 一:bind(t ...

  8. Javascript绑定事件的两种方式的区别

    命名函数 <input type="button" onclick="check()" id="btn"/> <scrip ...

  9. jQuery绑定事件的四種方式

    这篇文章主要介绍的是jQuery绑定事件的四种方式相关内容,下面我们就与大家一起分享. jQuery绑定事件的四种方式 jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点 ...

随机推荐

  1. STL--map用法

    STL--map用法map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力由于这个特性它完成有可能在我们处理 ...

  2. Android Baseline小tip

    转载请注明出处:http://blog.csdn.net/bbld_/article/details/40709353 Baseline Alignment

  3. min-width 和 @media screen

    min-width可以容器设置最小宽度,低于改宽度时,会自动加上滚动条,支持ie7及ie7+: @media only screen and (min-width: /*最小宽度(要加单位px)*/) ...

  4. bzoj4664: Count

    是bzoj4498: 魔法的碰撞的哥哥题,我只写了一种 不一样的地方在于贡献有负数,第三维要保存的不能仅仅是0~L,这样空间会炸裂 考虑如何把贡献变成正的 假如要求最优解,那么一定是按顺序排,混乱度为 ...

  5. 网络转载:局域网安全:解决ARP攻击的方法和原理

    局域网安全:解决ARP攻击的方法和原理 IT世界网2006-01-26 10:17   [故障原因] 局域网内有人使用ARP欺骗的木马程序(比如:传奇盗号的软件,某些传奇外挂中也被恶意加载了此程序). ...

  6. css清除浮动float的七种常用方法总结和兼容性处理

    在清除浮动前我们要了解两个重要的定义: 浮动的定义:使元素脱离文档流,按照指定方向发生移动,遇到父级边界或者相邻的浮动元素停了下来. 高度塌陷:浮动元素父元素高度自适应(父元素不写高度时,子元素写了浮 ...

  7. ewasm项目初探

    为了改进EVM1.0,以太坊的新一代虚拟机项目ewasm (github.com/ewasm)将支持WebAssembly(wasm),wasm在性能,扩展性,开发工具,社区都更有优势.除以太坊外,一 ...

  8. JQuery判断div(控件)是否为隐藏

    以下是JavaScript 中判断div是否为隐藏代码引用片段: if (div.style.display == "none") { div.style.display = &q ...

  9. putty与emacs

    win环境下putty登录到linux并使用emacs时,需要折腾好配置才能正常工作.下面是折腾过程中碰到的问题与解决步骤: 1)要在putty控制台中启用鼠标,只需要在.emacs配置文件中启用xt ...

  10. UIScrollView控件介绍

    1.UIScrollView控件是什么? (1)移动设备的屏幕⼤大⼩小是极其有限的,因此直接展⽰示在⽤用户眼前的内容也相当有限 (2)当展⽰示的内容较多,超出⼀一个屏幕时,⽤用户可通过滚动⼿手势来查看 ...