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>
相关推荐
吴声子夜歌几秒前
小程序——跳转API
服务器·前端·小程序
m0_50272495几秒前
CSS position 属性的所有取值(2024最新)
前端·css
银河麒麟操作系统4 分钟前
桌面通用(全架构)【IE浏览器内核插件与 Chrome 内核浏览器插件的区别及兼容性分析】技术文章
前端·chrome
不知名。。。。。。。。10 分钟前
仿muduo库实现高并发服务器--日志的书写和套接字Socket的实现
前端
夫琅禾费米线13 分钟前
React Hook Form + Zod:优雅构建 React 表单
前端·javascript·react.js·typescript
坐吃山猪17 分钟前
React+TypeScript Agent开发规范
前端·react.js·typescript
SuperEugene23 分钟前
Vue3 表格封装实战:列配置 + slot 扩展 + 请求生命周期|Vue生态精选篇
前端·javascript·vue.js·前端框架
小鹿软件办公30 分钟前
Firefox Nova:火狐浏览器即将迎来大规模改版
前端·firefox
Lee_Yu_Fan31 分钟前
在vue3 + ElementUI 项目中自定义 Icon
前端·elementui