Vue底层原理之变化侦测 —— 让对象每一个属性都变得“可侦测

在这里插入图片描述

1. 说在前面


1.1 Vue的两大特性

  • 组件系统:把页面抽象成多个相对独立的模块,实现代码重用,提高开发效率和代码质量,便于代码维护。

  • 数据驱动:宗旨是以数据驱动,减少dom操作。

数据可以理解为状态,视图即是用户所见页面,它是动态变化的,根据用户的操作或者后台数据变化来,状态变化视图(也就是页面)也会随之改变,所以我们得到了这样一个公式:

在这里插入图片描述

  • state是状态输入,页面UI是得到的结果,状态改变,页面随之改变,这便是数据驱动视图。

  • state与UI是用户所定义,render()是固定的,所以这也是Vue扮演的角色。

  • 那么,**Vue怎么知道state变化了呢?**😧😧

1.2 变化侦测的定义

  • 我们期望出现的结果是:Vue能够监听到数据的变化,既而改变视图。

  • 变化侦测即是追踪数据状态,一旦数据变化,就去更新视图

2. 使Object数据“可侦测”


2.1 单个属性监听

  • 如果我们要监听以下对象的某个属性:

let obj = {

name: ‘小明’,

age: 18

}

众所周知,我们可以对这个对象里的任意属性进行增删改查等诸多操作,那么,我们如何才能知道:**操作的具体属性是哪个,操作完的结果变成了什么?**😣😣

  • 接下来,轮到Object.defineProperty() 出场了

let value = ‘小明’;

Object.defineProperty(obj, “name”, {

get: function() {

console.log(“取值”)

return value;

},

set: function(val) {

console.log(新值${value})

value = val

}

})

  • 这样便可以知道name属性的变化,读取和操作都能监听到

在这里插入图片描述

在这里插入图片描述

  • name 属性我们可以监测到变化与读取,但是age属性是不行的

  • 数据虽有变化,但是没法捕获,这显然是不对的,(就好像我娶了几个漂亮老婆,不发朋友圈让大家知道,炫耀一番,心里总是不舒服的

在这里插入图片描述

3. 让对象所有属性都变成“可观测”


observer.js 实现

  • 为了让obj里的每一个数据都变得可观测,我们可以写一个专门负责侦听的类,代码如下:

  • 注释也写的明明白白的,别忘了给个三连(给大家拜年了🙏🙏🙏)

export class Observer {

// 初始化

constructor(value) {

this.value = value

if(Array.isArray(value)){

// 数组的逻辑

}else{

// 对象的逻辑

this.walk(value)

}

}

// 先考虑对象

// 具体的操作

walk(obj) {

const keys = Object.keys(obj) // []

for(let i = 0; i < keys.length; i++){

defineReactive(obj, keys[i])

}

}

}

// 让一个对象转化成可观测对象

function defineReactive(obj, key, val){

// 减少一个变量

if(arguments.length === 2){

val = obj[key] // 当前项的值 => 基本类型?引用类型

}

// 引用类型,递归深层对象

if(typeof val === “object”){

new Observer(val)

}

Object.defineProperty(obj, key, {

enumerable: true, // 可枚举

configurable: true, // 可删除

get() {

console.log(${key}属性被读取${val})

return val

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

分享

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-JM42DR83-1712007955339)]

分享

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 14
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值