前端页面出现问题ResizeObserver loop completed with undelivered notifications.

报错内容

ai说是因为 "某个 ResizeObserver 的回调里又触发了尺寸变化,导致浏览器不得不跳过一帧通知,以避免无限循环。"

开发环境下 webpack-dev-server 会把这条警告通过 error-overlay 弹出来,生产环境不会崩,但看着烦。

解决方法1------把警告本身吞掉

在入口文件(src/index.js 或 main.ts 最顶部)加 3 行即可,只吞 ResizeObserver 的这条 loop 警告,其它报错照常吃:

cpp 复制代码
// src/index.js
if (typeof window !== 'undefined') {
  window.addEventListener('error', e =>
    e.message?.includes('ResizeObserver loop completed with undelivered notifications') && e.preventDefault()
  );
}

但是还是不行

解决方法2------直接关掉 dev-server 的 error-overlay

package.json的 scripts 里把启动命令改成

cpp 复制代码
"start": "webpack serve --client-overlay=false"

还是不行

解决方法3

在 App.vue 文件中加入防抖函数。

cpp 复制代码
<script setup>
import { onMounted, onUnmounted } from 'vue'
import { debounce } from 'lodash'

// 防抖处理 ResizeObserver 回调
const debouncedResizeObserver = debounce(() => {
  // 这里可以添加需要防抖的逻辑
}, 100)

// 重写 ResizeObserver 构造函数
onMounted(() => {
  const OriginalResizeObserver = window.ResizeObserver
  
  window.ResizeObserver = class extends OriginalResizeObserver {
    constructor(callback) {
      const debouncedCallback = debounce(callback, 16) // 约60fps
      super(debouncedCallback)
    }
  }
})

onUnmounted(() => {
  // 清理
  debouncedResizeObserver.cancel()
})
</script>

成功解决

相关推荐
方也_arkling9 分钟前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐11 分钟前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区25 分钟前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO44 分钟前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121381 小时前
Vuex介绍
前端·javascript·vue.js
We་ct1 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480062 小时前
【无标题】
开发语言·前端·javascript
css趣多多2 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会2 小时前
Web学习之用户认证
前端·学习
We་ct2 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表