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

2025-07-06 04:06:34

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会“知道”吗?
声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢