记项目问题-1

使用 Echarts 时,控制台警告:

Added non-passive event listener to ascroll- blocking 'mousewheel’event Consider marking event handler as ’passive’ to make the page more responsive

// 1. 安装依赖

npm i import default-passive-events

// 2. 项目 main.ts 引入

import 'default-passive-events';

使用 vben 的分页器,在修改pageSize时会报错,与依赖 default-passive-events 有关,报错如下:

Unable to preventDefault inside passive event listener invocation

通过修改 EventTarget.prototype.addEventListener 方法来解决这个问题。在新定义的方法中,代码检查了 capture 参数是否为布尔值。如果 capture 参数不是布尔值,代码将其设置为一个空对象,并将 passive 属性设置为 false

通过对 addEventListener 方法进行修改,确保在没有明确设置 capture 参数为 true 的情况下,其默认值为 false。这样一来,就避免了在触发事件时出现报错的问题。

(function () {
  if (typeof EventTarget !== 'undefined') {
    const func = EventTarget.prototype.addEventListener;
    EventTarget.prototype.addEventListener = function (type, fn, capture) {
      (this as any).func = func;
      if (typeof capture !== 'boolean') {
        capture = capture || {};
        capture.passive = false;
      }
      (this as any).func(type, fn, capture);
    };
  }
})();


// 在main.ts中引入
import '@/utils/browserPatch';

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值