news 2026/1/19 21:25:05

Vue MutationObserver 监听

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/19 1:10:34

【课程设计/毕业设计】基于springboot的校园二手交易平台物品管理-求购物品 ◦ 学生管理【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/1/18 5:34:50

开源大模型+TensorRT镜像超强推理组合?真相来了

开源大模型TensorRT镜像超强推理组合&#xff1f;真相来了 在生成式AI浪潮席卷各行各业的今天&#xff0c;越来越多企业试图将LLaMA、Falcon、ChatGLM等开源大模型部署到生产环境。然而&#xff0c;现实往往令人沮丧&#xff1a;一个7B参数的模型&#xff0c;在PyTorch下逐toke…

作者头像 李华
网站建设 2026/1/17 7:15:50

django基于Python豆瓣电影数据可视化分析设计与实现

背景分析随着互联网和数字化娱乐的快速发展&#xff0c;电影产业数据呈现爆炸式增长。豆瓣作为国内权威的电影评分平台&#xff0c;积累了海量用户评分、评论和电影元数据。这些数据蕴含用户偏好、市场趋势及文化现象&#xff0c;但原始数据难以直接洞察规律。通过数据可视化技…

作者头像 李华
网站建设 2026/1/18 13:04:03

大模型服务成本太高?用TensorRT降低90%推理开销

用TensorRT降低90%推理开销&#xff1a;大模型落地的性价比革命 在AI服务从实验室走向生产环境的过程中&#xff0c;一个现实问题正变得越来越尖锐&#xff1a;为什么训练好的大模型一上线&#xff0c;成本就高得让人喘不过气&#xff1f; 你可能经历过这样的场景——一个微调后…

作者头像 李华
网站建设 2026/1/17 8:39:54

django基于Spark的南昌房价数据分析系统的设计与实现

背景分析房地产行业作为国民经济支柱产业之一&#xff0c;房价波动直接影响民生与经济稳定。南昌作为江西省会城市&#xff0c;近年来城市化进程加速&#xff0c;房价呈现复杂变化趋势。传统数据分析方法受限于处理能力和实时性&#xff0c;难以应对海量房产数据&#xff08;如…

作者头像 李华