2016 - 2024

感恩一路有你

v-model双向绑定原理 Vue是如何实现双向数据绑定的?

浏览量:2826 时间:2021-03-17 15:11:30 作者:admin

Vue是如何实现双向数据绑定的?

数据与视图的绑定与同步,最终体现在对数据的读写处理过程中,也就是 Object.defineProperty() 定义的数据 set、get 函数中。Vue 中对于的函数为 defineReactive,在精简版实现中,我只保留了一些基本特性:

function defineReactive(obj, key, value) {

var dep = new Dep()

Object.defineProperty(obj, key, {

enumerable: true,

configurable: true,

get: function reactiveGetter() {

if (Dep.target) {

dep.depend()

}

return value

},

set: function reactiveSetter(newVal) {

if (value === newVal) {

return

} else {

value = newVal

dep.notify()

}

}

})

}

在对数据进行读取时,如果当前有 Watcher(对数据的观察者吧,watcher 会负责将获取的新数据发送给视图),那将该 Watcher 绑定到当前的数据上(dep.depend(),dep 关联当前数据和所有的 watcher 的依赖关系),是一个检查并记录依赖的过程。而在对数据进行赋值时,如果数据发生改变,则通知所有的 watcher(借助 dep.notify())。这样,即便是我们手动改变了数据,框架也能够自动将数据同步到视图。

Vue动态生成的input怎么实现数据双向绑定?

你可以用渲染的时候让 h 这种动态生成的方法来加上this.my_variables 下面是例子或者使用$refs,给你的input一个id,然后获取到以后,用compute好的值给他赋值;renderHeader: (h)=>{return h("div",[h("strong","序号"),h("Icon",{props:{type: this.my_variables},style: {marginLeft: "5px"}})])},我也是在学习,希望能有所帮助

只有我一个人感觉Layui和Vue差别不大吗?

layui基于jquery,当然很多地方也是直接操作josn数据,绑定数据直接显示,vue底层是操作虚拟dom,实现数据绑定,其实开发者不用关心,写法vue还需要在dom指定位置上绑定data,甚至要做一些逻辑,比如v-if等,layui其实是已经封装好的方法直接调用。

vue有个最大的问题是,如果页面很复杂,dom,data,method这三者因为不在一个地方,找起来要人命,当然vue3解决了,可以把所有逻辑写一个function,我个人还是觉得简单的页面用vue,复杂的业务逻辑多的用jquery

v-model双向绑定原理 vue复选框实现双向数据绑定 vue双向数据绑定原理是什么

版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。