码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【前端】记录各种控制台警告/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的根节点可能不是这样的元素。

    确认组件的根节点是否为一个有效的 DOM 元素

    2、Ignored: ResizeObserver loop limit exceeded

    element-plus 使用el-table 在切换tab栏时报错:
    在这里插入图片描述
    原因:ResizeObserver不能处理所有的observations导致报错;

    解决方法:
    1.阻止table的重绘,给每个设置固定的width,缺点是无法自适应宽度。
    2.给每个设置min-width
    3.添加debounce()防抖方法,在App.vue文件中添加:

      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中添加以下代码:

    // 解决 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);
    
  • 相关阅读:
    (4)点云数据处理学习——其它官网例子
    【我不熟悉的javascript】02. 新手菜鸟们,求你不要再用console.log了,console.table用起来,提升效率的小方法
    Unity设计模式——原型模式
    搭建 GPT-2 模型训练环境
    数学建模学习(92):gurobipy详细入门教程【MLP、MIP模型、仓库调度模型、单/多目标优化、敏感性分析】
    谈谈对跨域(跨源)的一些理解
    网络安全(黑客)自学
    Hudi(三)集成Flink
    Hadoop+Zookeeper+HA错题总结(一)
    json----fastjson的使用,jackson的使用
  • 原文地址:https://blog.csdn.net/cpsxn/article/details/131126297
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号