首页
学习
活动
专区
圈层
工具
发布

jQuery中on()、bind()、live()、delegate()之间的区别

jQuery的.on()、.bind()、.live()和.delegate()之间的区别并非总是那么明显的,然而,如果我们对所有的不同之处都有清晰的理解的话,那么这将会有助于我们编写出更加简洁的代码,...在操纵DOM的语境中,document是根节点。 现在我们可以较容易地说明.on()、.bind()、.live()和.delegate()的不同之处了。...及其以上版本;jquery1.7版本出现之后用于替代bind(),live()绑定事件方式; event 必需项;添加到元素的一个或多个事件,例如 click,dblclick等; 单事件处理:例如...接下来就详细说下几者之间的区别: 1 .bind() .bind()是直接绑定在元素上,也很好的解决了浏览器在事件处理中的兼容问题。...它会绑定事件到所有的选出来的元素上 它不会绑定到在它执行完后动态添加的那些元素上 当元素很多时,会出现效率问题 当页面加载完的时候,你才可以进行bind(),所以可能产生效率问题 2 .live()

1.5K30

浅析 FP:JavaScript 中的纯函数

前言 纯函数 是一个常见的概念,在日常工作中也经常会遇到,它其实非常简单,今天我们来了解一下它的好处以及为什么要使用它。...那我们如果换成纯函数版本的 greet ,所有都是那么自然~ 只需要修改单元测试中传入的参数即可! 可缓存性(Cacheable) 纯函数可以根据输入来做缓存。...cached 中的那个函数为纯函数的基础上。...可移植性 / 自文档化(Portable / Self-Documenting) 由于纯函数是自给自足的,它需要的东西都在输入参数中已经声明,所以它可以任意移植到任何地方。...纯函数就是这么个正直的小可爱~ 总结 好啦,我们已经大概了解了纯函数,它对于我们写出良好代码有着重要的意义,同时也是函数式编程中的精髓。

70920
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    jQuery中find&filter、live&bind对比介绍及图片懒加载

    之所以jquery要保留bind方法而不是采用live方法去替代bind,也是因为live在某些情况下是不能够完全替代bind的。...如下: 1. bind方法可以绑定任何JavaScript的事件,而live方法在jQuery1.3的时候只支持click、dblclick、 keydown、 keypress、 keyup、mousedown...在jQuery 1.4.1中,甚至也支持 focus 和 blue事件了(映射到更合适,并且可以冒泡的focusin和focusout上)。...另外,在jQuery 1.4.1中,也能支持hover(映射到"mouseenter、mouseleave")。 2. live() 并不完全支持通过DOM遍历的方法找到的元素。...将整个窗口看成是一个大容器,那么也可以在页面中设置一个小容器,在小容器中也同样可以实现图片的延迟加载。 实例插件下载地址:http://pan.baidu.com/s/1c01sSaW

    84231

    JavaScript 中的函数式编程:纯函数与副作用

    在 JavaScript 中,函数式编程的应用越来越广泛,为开发者提供了一种更简洁、更可维护的编程方式。纯函数的定义与特性纯函数是函数式编程的核心概念之一。...缓存友好:由于纯函数对于相同的输入总是产生相同的输出,所以可以利用缓存来提高性能。副作用的概念与表现形式副作用则是指函数在执行过程中,除了返回值之外,还对外部环境产生了其他的影响。...遵循单一职责原则:确保每个函数尽量只负责一个明确的任务,避免将纯逻辑和副作用混合在一个函数中。...纯函数和副作用是函数式编程中的两个核心概念。纯函数提供了确定性和无副作用的特性,使得代码更易于理解和维护。副作用虽然不可避免,但我们可以通过合理的设计和管理来控制其影响。...通过在 JavaScript 中运用纯函数和副作用管理技巧,我们可以编写出更健壮、更可维护的代码。

    41400

    在 .NET Core 中运行 JavaScript

    一.前言 在 .NET Framework 时,我们可以通过V8.NET等组件来运行 JavaScript,不过目前我看了好几个开源组件包括V8.NET都还不支持 .NET Core ,我们如何在 .NET...Core 中运行 JavaScript 呢,答案是使用 NodeServices。...关于为何有在 .NET Core 中执行 JavaScript 这种需求,比较特殊,举个栗子:当你做模拟登录时,目标网站可能采用一些加密算法来计算特殊的值,如果你要完全模拟,那么除了用C#翻译这个算法还有个办法就是直接将这段加密算法...二.什么是 NodeServices NodeServices 是一个 ASP.NET Core 中间件,将它添加到 ASP.NET Core 管道中,该中间件调用Node在运行时执行JavaScript...首先,我们将首先创建一个包含返回问候消息的 NodeJs module 的简单JavaScript文件,保存在 scripts/greeter.js文件中: // greeter.js module.exports

    5K20

    在Node.js中逐行读取文件【纯技术】

    介绍 在计算机科学中,文件是一种资源,用于在计算机的存储设备中离散地记录数据。Node.js不会以任何方式覆盖它,并且可以与文件系统中被视为文件的任何文件一起使用。...它是在2015年添加的,旨在Readable一次从任何流中读取一行。 这个事实使它成为通用的选项,不仅适用于文件,甚至适用于诸如的命令行输入process.stdin。...在我们的情况下,我们不想使事情复杂化,而只是将其打印到控制台上。 在线阅读器 在详细说明了如何使用本机Node.js模块逐行读取文件之后,让我们使用npm 的开源行读取器模块来查看它的较短版本。...常见错误 在Node.js中逐行读取文件时,常见的错误是将整个文件读取到内存中,然后通过换行符分割其内容。...确保在一些极端情况下进行测试,例如巨大,空白或不存在的文件,并且最好使用提供的任何示例。

    8.7K20

    asp.net中ScriptManager自带Ajax与jQuery事件冲突

    问题解决办法: 方法1、两者实现都能够实现页面的无刷新效果,所以可以保留其中的一种即可; 方法2、如果必须要两者混合应用,那么在用jQuery绑定事件是就要注意一些了    我们平时在jQuery中绑定事件最常用的方式有以下三种...:以click事件为例    (1)target.click(function(){});-----和纯js绑定事件没得什么区别    (2)target.bind("click",function()...所以针对上面问题,只需要在绑定事件的时候使用target.live("click",function(){})方式即可(jQuery版本必须是在1.4及其以上) 下面简单说明一下jQuery通过bind...由于只有在事件发生的时候,live方法才会去检测绑定事件的对象是否存在,所以live方法可以实现后来新增的元素也可实现事件的绑定。.../javascript"> javascript"> $(function () { $(".asa

    1.2K10

    在现代 JavaScript 中编写异步任务

    Node.js 开辟了一个在不同环境中甚至在 web 之外编写 JavaScript 的新时代。当然异步的情况也是可能的,例如创建新目录或写文件。...对返回值进行的后续操作无需存储在不会破坏代码节奏的 mkdir 之类的变量中;也无需在以后的步骤中创建新的作用域来访问 result 的值。...可以肯定地说,Promise 是该语言中引入的基本工件,对于在 JavaScript 中启用 async/await 表示法是必需的,你可以在现代浏览器和最新版本的 Node.js 中使用它。...我们仍然不知道 ECMAScript 规范在几年后的样子,因为我们一直在将 JavaScript 治理扩展到 web 之外,并尝试解决更复杂的难题。...与十年前刚刚开始在浏览器中编写代码时相比,我觉得现在 JavaScript 是“异步友好”的。

    3.1K30

    策略模式 在JavaScript中的实现

    也就是违背了 开放-封闭原则 (Open-Close Principle,OCP) 分析 以上问题就很适合使用 策略模式 在JavaScript中,策略模式可以通过以下方式理解: 定义策略对象:首先,你需要定义一组策略对象...使用策略对象:在需要使用算法或行为的地方,你可以通过选择合适的策略对象来实现不同的功能。这样可以在不修改客户端代码的情况下改变算法或行为。...因为以上过程只需要表示为 解决方案 1 普通对象 在JavaScript中,对象 object 天然具备 判断哪种策略 - 使用策略能力 对象[策略](); obj[key](); // 定义策略对象...canvas.width / tileSize, canvas.height / tileSize, 0, 0, canvas.width, canvas.height); }, } // 在每一帧绘制视频画面到画布上

    1.1K00
    领券