只执行一次的事件绑定函数

概览
在前端开发中,有时会希望事件只被调用一次。比如,点击一张缩略图加载视频文件或点击“更多”图标通过AJAX展示额外的内容。
当多次点击的时候,事件处理函数会被调用多次,这会造成浏览器多次加载不必要的资源。更坏的情况可能会导致无法预期的事情发生。
使用JavaScript可以很容易的实现只绑定一次的事件。步骤如下:

(1)定义事件处理函数,比如点击事件处理函数
(2)点击元素执行事件处理函数
(3)移除事件处理函数。

原生JavaScript事件绑定
所谓的移除事件处理函数指的是对于给定的元素和事件类型,处理程序在第一次触发事件后会被立即解除绑定。直接上代码:

function once(type, selector, callback) {
    selector.addEventListener(type, function fn(e) {
        e.target.removeEventListener(e.type, fn);
        return callback(e);
    }, false);
}

现在就可以使用**once()**方法只让事件执行一次了:

once('click', buttonElement, function () {
    console.log('executed only once.');
});

除此之外,W3C标准提供一个事件绑定方法addEventListener,我们先来看看这个方法的API:

target.addEventListener(type, listener[, options])

其中,options对象提供一个once属性来指定事件绑定的次数,bool值。如果为true表示事件执行之后会自动移除绑定

var buttonEl = document.getElementById('w3c');
buttonEl.addEventListener('click', function (e) {
    console.log('W3C标准事件');
},{once: true});

Jquery事件绑定
jQuery提供了一个one()方法实现只绑定一次的事件。更多使用方法请参考one()方法文档。

$("#foo").one("click", function() {
    console.log("Event fired once!!!");
});

**one()其实是调用了on()方法,通过参数控制事件绑定的次数。**所以如果想要了解jQuery如何实现事件绑定,请看on()方法的实现。

one: function (types, selector, data, fn) {
    return on(this, types, selector, data, fn, 1);
}

Vue事件绑定
Vue中的通过修饰符once实现只触发一次事件处理程序的方式:

<button v-on:click.once="doThis"></button>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值