MutationObserver的使用

通过MutationObserver的方式监听是否有DOM元素插入。当vue渲染页面后会对<div id="app"></div>重新挂载。这时要观察的目标节点内会有节点挂载,此时隐藏骨架屏。

js 复制代码
<svg id="skeletonViewBase"></svg>
<div id="app"></div>
<script>
const skeleton_view_base = document.querySelector('#skeletonViewBase')
const observers = new MutationObserver((mutationsList, observer) => {
  // 遍历每个发生变化的 mutation
  for (const mutation of mutationsList) {
    // 检查是否有节点添加
    if (mutation.type === 'childList' && mutation.addedNodes.length > 0) {
      // 遍历新添加的节点
      mutation.addedNodes.forEach((node) => {
        if (node.classList) {
          skeleton_view_base && skeleton_view_base.remove()
          observer.disconnect()
        }
      })
    }
  }
})
// 要观察的目标节点
const targetNode = document.querySelector('#app')
// 配置 MutationObserver 来监听子节点的添加
const config = {
  childList: true, // 监听子节点的添加或移除
  subtree: true // 在整个 DOM 树中观察更改
}
// 开始观察
observers.observe(targetNode, config)
</script>
相关推荐
晴殇i10 分钟前
前端工程师必须掌握的SEO实战指南
前端·javascript·面试
problc24 分钟前
CSS 工具对比:UnoCSS vs Tailwind CSS,谁是你的菜?
前端·css
天天摸鱼的java工程师29 分钟前
互联网行业能力解刨:从Java后端八年开发经验看
前端·后端·程序员
brzhang36 分钟前
Android 16 卫星连接 API 来了,带你写出「永不失联」的应用
前端·后端·架构
John_ToDebug1 小时前
Chrome 浏览器前端与客户端双向通信实战
前端·c++·chrome
要加油哦~1 小时前
CSS | transition 和 transform的用处和区别
前端·css
小鱼人爱编程1 小时前
现代大前端是如何编码的?
android·前端·flutter
神仙别闹1 小时前
基于Java+VUE+MariaDB实现(Web)仿小米商城
java·前端·vue.js
袁煦丞1 小时前
低成本私有云存储方案Nas-Cab:cpolar实验室第508次成功挑战
前端·程序员·远程工作
小公主1 小时前
「前端必备」Flex 布局全解析:从入门到深度计算,搞懂弹性盒子!
前端·css