vue双向数据绑定原理面试_vue双向绑定原理

2022-11-02 15:40:18 浏览数 (1)

vue.js 则是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的settergetter,在数据变动时发布消息给订阅者,触发相应的监听回调。

vue实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个方法重新定义了对象获取属性值(get)和设置属性值(set)的操作来实现的。它接收三个参数,要操作的对象,要定义或修改的对象属性名,属性描述符。重点就是最后的属性描述符。属性描述符是一个对象,主要有两种形式:数据描述符和存取描述符。这两种对象只能选择一种使用,不能混合两种描述符的属性同时使用。上面说的get和set就是属于存取描述符对象的属性。在面试中如何应对?面试官:说一下VUE双向绑定的原理?答:VUE实现双向数据绑定的原理就是利用了 Object.defineProperty() 这个方法重新定义了对象获取属性值(get)和设置属性值(set)的操作来实现的。代码演示:defineProperty的用法var obj = { };var name;//第一个参数:定义属性的对象。//第二个参数:要定义或修改的属性的名称。//第三个参数:将被定义或修改的属性描述符。

Object.defineProperty(obj, “data”, {

//获取值

get: function ()

{ return name; },

//设置值

set: function (val) {

name = val;console.log(val)}})

//赋值调用

setobj.data = ‘aaa’;

//取值调用

getconsole.log(obj.data);

代码演示:defineProperty的双向绑定var obj={};Object.defineProperty(obj, ‘val’,{set:function (newVal) {document.getElementById(“a”).value =newVal==undefined?”:newVal;document.getElementById(“b”).innerHTML=newVal==undefined?”:newVal;}});document.getElementById(“a”).addEventListener(“keyup”,function (e) {obj.val = e.target.value;})

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/180776.html原文链接:https://javaforall.cn

0 人点赞