vue 源码解析 之test-passive事件

  最近在学习vue的源码,最开始看的的是vue.esm.js 这个文件,前面的内容,让我收获颇丰,觉得vue作者的强大之处;这么说吧,里面的方法直接可以拿出来做工具类了;

  但是看的这一段代码的时候,脑袋有点蒙:

var supportsPassive = false;
if (inBrowser) {
  try {
    var opts = {};
    Object.defineProperty(opts, 'passive', ({
      get: function get () {
        /* istanbul ignore next */
        supportsPassive = true;
      }
    }));
    window.addEventListener('test-passive', null, opts);
  } catch (e) {}
}

    以为是要声明一个事件,之后用,但是看到 addEventListener函数的第二个参数为null,就觉得事情没这么简单; 之前在看书或者查阅资料的时候,记得addEventListener 方法的第三个参数是一个Boolean类型的,但是这里传递的是一个Object类型;

    在此有目的的查阅文档后,才知道addEventListener第三个函数也可以接受一个对象最为参数 原文在这 文档 ;

   

  当vm执行到这里的时候,会读取opts对象的passive的值,这样就触发 passive的get函数,suppoptsPasive 就会变为true;

  所以这段代码是用来检查,当前环境是下addEventListener是否支持passive 属性;

  相信有人会有同样的疑问,特特此记录,共同进步;如果你有不同见解,请指教!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值