首页 > 其他分享 >【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set

【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set

时间:2022-10-16 16:31:08浏览次数:51  
标签:面试题 set Object Vue defineProperty 原理 setter data 页面


【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set_vue.js

响应式是什么?Vue 最独特的特性之一~

就是我们在页面开发时,修改data值的时候,数据、视图页面需要变化的地方变化。

主要使用到哪些方法?

用 ​​Object.defineProperty给watcher对象的每一个属性分别定义了get和set。getter负责记录依赖,setter负责数据拦截、对data属性的赋值和修改dom更新。大白话就是通过数据劫持 defineProperty + 发布订阅者模式。​

深入讲解

官方原文

一个普通的 JavaScript 对象传入 Vue 实例作为 ​​data​​​ 选项,Vue 将遍历此对象所有的 property,并使用 ​​Object.defineProperty​​ 把这些 property 全部转为 getter/setter。 

这些 getter/setter 对用户来说是不可见的,但是在内部它们让 Vue 能够追踪依赖,在 property 被访问和修改时通知变更。这里需要注意的是不同浏览器在控制台打印数据对象时对 getter/setter 的格式化并不同,所以建议安装 ​​vue-devtools​​ 来获取对检查数据更加友好的用户界面。

每个组件实例都对应一个 watcher 实例,它会在组件渲染的过程中把“接触”过的数据 property 记录为依赖。之后当依赖项的 setter 触发时,会通知 watcher,从而使它关联的组件重新渲染。

【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set_数组_02

 实现一个‘简易版双向绑定’

 1.创建一个data对象,页面为空白,defineProperty绑定data.a。

<div id="app">
<!-- 显示data.a的值 -->
//{{data.a}}
//app依赖于data中的a

</div>
<script>
const data={a:1}
//在vue中每一个data属性都有一个Object.defineProperty

Object.defineProperty(data,'a',{
get:function(){
console.log(`访问a`);
},
set:function(value){
document.getElementById('app').innerHTML=value
}
})

</script>
复制代码

2.测试效果

在页面访问data值,会实时展示。当有人访问到了a属性就会触发get这个函数。

【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set_vue.js_03

在页面修改data值,页面会实时展示。当有人给a进行赋值的时候就会触发set这个函数。

data.a=10

页面

【面试题】vue2双向绑定原理:深入响应式原理defineProperty、watcher、get、set_数据_04

 这时视图发生变化,符合Vue双向数据绑定的原理,即:数据=>视图,也可以的到的是set里面value的值是输入的10。

缺陷

  1. ​在ES5中无法shim:Object.defineProperty​​ 是 ES5 中一个无法 shim 的特性,这也就是 Vue 不支持 IE8 以及更低版本浏览器的原因。(shim:可以将新的API引入到旧的环境中,而且仅靠就环境中已有的手段实现);
  2. 由于 JavaScript 的限制,Vue 不能检测数组和对象的变化:
  • object.defineproperty 无法监控到数组下标的变化,导致通过数组下标添加元素,无法实时响应;
  • object.defineProperty 只能劫持对象的属性,从而需要对每个对象,每个属性进行遍历,如果,属性值是对象,还需要深度遍历。


标签:面试题,set,Object,Vue,defineProperty,原理,setter,data,页面
From: https://blog.51cto.com/u_14627797/5760433

相关文章

  • 01 计算机概要与技术 | 计算机组成原理
    1.程序概念入门1.软件的层次结构层次结构操作系统的作用处理基本的输入和输出分配外存和内存为多个应用程序提供共享计算机资源的服务2.从高级语言到硬件......
  • Python面试-数据类型面试题
    1.元祖类面试题tup1=(10)tup2=(10,)tup3=()print(type(tup1),type(tup2),type(tup3))"""输出结果:<class'int'><class'tuple'><class'tuple'>""" ......
  • 集合—HashSet
    HashSet和ArrayList区别:HashSet无序不可重复,ArrayLIst有序可重复HashSet(无序不重复)1.add方法//以下会去掉重复值hashSet.add(100);hashSet.add(100);System.out.p......
  • 包装类的面试题
    packageWrapperTest;importorg.junit.Test;/***@authorliu$*@version1.0*@description:TODO*@date$$*/publicclasswraptest{publicvoidtest(){......
  • Mysql单表访问方法,索引合并,多表连接原理,基于规则的优化,子查询优化
    参考书籍《mysql是怎样运行的》非常推荐这本书,通俗易懂,但是没有讲mysql主从等内容书中还讲解了本文没有提到的子查询优化内容,本文只总结了常见的子查询是如何优化的系......
  • Nacos启动报错:Please set the JAVA_HOME variable in your environment, We need java
    可能原因:1.JDK版本过低(应不低于1.8)2.未设置jdk环境变量(可能性低)3.jdk环境变量设置不适配nacos(博主就是这个原因) 解决方案:1.直接在startup.cmd文件中设置JA......
  • 面试题:JAVA多线程交替打印ABC
    JAVA实现,3个线程交替A,B,C,一共完成10次“ABC”打印,结束后打印“END”。打印示例:abcabcabcabcabcabcabcabcabcabcEND 分析:打印10次ABC,3个线程分别打印A,B......
  • 02 指令 | 计算机组成原理
    1.指令系统1.指令系统概述指令系统:是计算机硬件的语言系统,它是软件和硬件的主要界面,从系统结构的角度看,指令系统表征了计算机的基本功能,决定了机器所要求的能力指令......
  • Vue面试题33:$attrs和$listeners是做什么的以及它们的使用场景(总结自B站up主‘前端杨村
    分析API考察,但$attrs和$listeners是比较少用的边界知识,而且vue3有变化,$listeners已经移除,还是有细节可说的;思路1.这两个api的作用;2.使用场景分析;3.使用方式和......
  • redis:set类型
    Redis的Set结构与Java中的HashSet类似,可以看做是一个value为null的HashMap。因为也是一个hash表,因此具备与HashSet类似的特征:无序元素不可重复查找快支持交集......