Vue MutationObserver 监听

MutationObserver 之前写过一篇详解,具体可参考:https://blog.csdn.net/qq_36020334/article/details/156300319?spm=1001.2014.3001.5502

在前端基于Vue的开发中,Vue2用watch来监听数据的变化,通过deep属性的配置项来监听对象内部的变化。 在 Vue3 中使用 proxy 替代了defineProperty 来监听整个对象,便利程度大大提高。

但有时候会遇到这样一些特殊情况,例如:想要给一个按钮动态的绑定一个样式,这个样式的绑定依赖于定义的一个变量,但是该变量也是动态的,变量的值依赖于另外一个内部组件样式的变化。 这就用到了 MutationObserver 去监听一个特定样式的变化,进而去实现业务的需求

代码实现:

复制代码
<template>
  <div :class="{'mycolor':isActive}" class="content">
    <el-button
      type="primary"
      class="el-button"
      @click.stop="openDialog"
      >打开弹窗</el-button
    >
    <el-dialog
      ref="dialog"
      title="我是弹窗啊"
      width="300px"
      :visible="false"
      :before-close="dialogBeforeClose"
    >
      <div></div>
      <div slot="footer">
        <el-button @click="dialogBeforeClose">取 消</el-button>
        <el-button type="primary" @click="dialogBeforeClose">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>
<script>
export default {
  name: "testContent",
  data() {
    return {
      isActive: false,
    };
  },
  mounted() {
    this.$nextTick(() => {
      this.watchDialogStyle(this.$refs.dialog.$el);
    });
  },
  methods: {
    openDialog() {
      this.$refs.dialog.$el.style.display = "block";
    },
    dialogBeforeClose() {
      this.$refs.dialog.$el.style.display = "none";
    },
    watchDialogStyle(dialog) {
      const observer = new MutationObserver( (mutations) =>  {
      mutations.forEach((mutation) => {
          if(dialog.style.display === 'none'){
            this.isActive = true;
          }
          else{
            this.isActive = false;
          }
        });
      });
      observer.observe(dialog, {
        attributeFilter: ["style"]
      });
    },
  },
};
</script>
相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
像我这样帅的人丶你还1 天前
别再让JS耽误你进步了。
css·vue.js
@yanyu6661 天前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript