【前端】记录各种控制台警告/bug

一、Element Plus

1、控制台警告:"Runtime directive used on component with non-element root node. The directives will not function as intended."

错误原因:在 Vue 组件上使用了运行时指令(指那些在运行时动态绑定到 DOM 元素上的指令),但是该组件的根节点不是一个标准的 DOM 元素(例如 div 或 span)

原因:自定义指令不能放到组件上,而是要放到自有的元素上。

解决方法

1.找到报警告的位置, 确认组件的根节点是否为一个有效的 DOM 元素

2.运行时指令:v-loading、v-show、v-if...

3.如下图示例:el-dialog上不能使用自定义指令v-loading

Element UI 和 Element Plus 中的 el-dialog组件本身是一个封装好的组件,它有自己的内部结构和生命周期。当你尝试在 el-dialog 上使用 v-loading指令时,可能会遇到一些问题,主要是因为 v-loading 指令期望的是一个标准的 DOM 元素,而 el-dialog的根节点可能不是这样的元素。

2、Ignored: ResizeObserver loop limit exceeded

element-plus 使用el-table 在切换tab栏时报错:

原因:ResizeObserver不能处理所有的observations导致报错;

解决方法:

1.阻止table的重绘,给每个<el-table-column>设置固定的width,缺点是无法自适应宽度。

2.给每个<el-table-column>设置min-width

3.添加debounce()防抖方法,在App.vue文件中添加:

javascript 复制代码
  const debounce = (fn, delay) => {
  let timer = null;
  return function () {
    let context = this;
    let args = arguments;
    clearTimeout(timer);
    timer = setTimeout(function () {
      fn.apply(context, args);
    }, delay);
  }
}

const _ResizeObserver = window.ResizeObserver;
window.ResizeObserver = class ResizeObserver extends _ResizeObserver{
  constructor(callback) {
    callback = debounce(callback, 16);
    super(callback);
  }
}

4.给回调进行节流,在App.vue中添加以下代码:

javascript 复制代码
// 解决 ElTable 自动宽度导致的「ResizeObserver loop limit exceeded」问题
const fixElTableErr = (table) => {
    const oldResizeListener = table.methods.resizeListener;
    table.methods.resizeListener = function () {
        window.requestAnimationFrame(oldResizeListener.bind(this));
    };
};
// 在Vue.use之前执行此函数
fixElTableErr(Table);
相关推荐
Hoey12 分钟前
虚拟 DOM 和 DIFF 算法
前端·vue.js
bkspiderx14 分钟前
HTTP协议:Web通信的“通用语言”解析
前端·网络协议·http
云水一下15 分钟前
模块系统与 npm——万物皆模块
前端·npm·node.js
无风听海21 分钟前
PKCE 的 S256 算法深度剖析:从协议设计到密码学原理
javascript·网络·算法·密码学
ZC跨境爬虫23 分钟前
跟着 MDN 学CSS day_47:(移动优先实战——从手机到宽屏的响应式进化)
前端·css·html·tensorflow·媒体
小新11024 分钟前
vue实战项目 计算器
前端·javascript·vue.js
秋田君25 分钟前
2026 前端新出路:掌握 C++ 核心语法,无缝衔接 QT 桌面开发
前端·c++·qt
老毛肚36 分钟前
jeecgboot vue 路由 拆分01
前端·javascript·typescript
ZC跨境爬虫37 分钟前
跟着 MDN 学CSS day_46:(响应式实战——用媒体查询打造双列布局)
前端·css·ui·html·tensorflow·媒体
狗凯之家源码网39 分钟前
多语言企鹅养殖投资返利系统 自定义产品配置 一键部署源码
前端·架构·php