【elementplus】解决改变屏幕大小时el-table报错ResizeObserver loop limit exceeded

作者: TAIS3 分类: JavaScript,VUE 发布时间: 2024-01-16 10:02

该报错虽然不影响项目运行,但是影响开发效率,总是弹出报错的黑框很烦人

该报错原因:new ResizeObserver包裹的方法,在布局发生变化时,不支持每帧都调用

解决方法:用 window.requestAnimationFrame包裹回调函数

App.vue/main.js中加入以下这段代码即可解决:

// app.vue写在script里面  main.js写在app挂在完之后
const debounce = (fn, delay) => {
  let timer
   return (...args) => {
     if (timer) {
       clearTimeout(timer)
     }
     timer = setTimeout(() => {
       fn(...args)
     }, delay)
   }
}
  
const _ResizeObserver = window.ResizeObserver;
window.ResizeObserver = class ResizeObserver extends _ResizeObserver{
   constructor(callback) {
     callback = debounce(callback, 200);
     super(callback);
   }
}

文章来源于互联网:【elementplus】解决改变屏幕大小时el-table报错ResizeObserver loop limit exceeded

发表回复