网站首页 美食营养 游戏数码 手工爱好 生活家居 健康养生 运动户外 职场理财 情感交际 母婴教育 生活知识 知识问答

用js修改dom,vue会“知道”吗?

时间:2024-11-08 13:35:16

1、本文基础知识是理解vue的虚拟dom;简单来说:在一个Vue作用域内整个人dom树结构都在vue的js控制下,页面中dom的修改需要vue遍历一遍,然后对比dom修改部分,然后对修改部分做处改变,未修改的不改变。以此来减少dom操作。那么问题来了!js 手动修改dom会不会被vue捕获的到,于是做了以下Demo

2、切记script引入vue2html代码:<div id="app"> <div id="name1">{{name}}</div> <input type="text" id="name" v-model="name"> <button @click="changeval()">123</button></div>先上js代码var app = new Vue({ el: '#app', data: { name :"aaa", }, watch: { name:function () { console.log(this.name); } }, methods: { changeval:function () { document.getElementById('name').value='HTML'; console.log(this.name); } } })

3、第一步:首先测试修改name的值,会触发watch

用js修改dom,vue会“知道”吗?

4、第二步:点击button -> 123即修改value值,并没有执行watch里的函数,且变量name的值为原来的值

用js修改dom,vue会“知道”吗?

5、第三步:再次修改input里的内容,watch 再次获取

用js修改dom,vue会“知道”吗?

6、帮助到你的话,请帮我投票,互惠,谢谢。

用js修改dom,vue会“知道”吗?
© 2026 智德知识库
信息来自网络 所有数据仅供参考
有疑问请联系站长 site.kefu@gmail.com