vue2深度监听以及重写数组方法
创始人
2024-06-01 21:04:28
0

VUE2 深度监听以及重写数组

在vue2中,实现监听主要用到的api为Object.defineProperty,提前声明一下,这个api不能监听数组的变化,只能监听对象的变化。因此,如果想要监听数组的变化,需要将数组转换成对象

如果不了解这个api的,可以查看Object.defineProperty() - JavaScript | MDN (mozilla.org)

如何实现深度监听呢?简单来说,就是递归思想的实现。

function updateView() {console.log("update");
}// 定义核心Function
function defineReactive1(target, key, value) {// 传过来,继续进行深度监听。observer(value);Object.defineProperty(target, key, {get() {return value;},set(newValue) {if (value != newValue) {// 如果是对象还要继续深度监听observer(newValue);value = newValue;// 通知视图更新。updateView();}}})
}// 遍历属性的api
function observer(target) {// 如果不是对象就返回,这个函数的目的就是深度遍历对象属性。if (typeof target !== 'object' || typeof target === null) {return target;}// 遍历返回。for (let key in target) {defineReactive1(target, key, target[key]);}}// test
let obj = {name:'jack'
}
observer(obj);
obj.name = 'marry';
console.log(JSON.stringify(obj));

解释几点:

  • observe的主要目的是如果键值还是对象,那么将继续监听。
  • defineReactive的主要作用是利用Object.defineProperty实现监听。因为有observe的api加持,所以能够确保defineProperty监听的值为基本值。

重写数组方法

Object.defineProperty是监听不了数组的,因此,如果需要监听数组,就需要将数组转换为对象。

let oldArrayProperty = Array.prototype;
const arr = Object.create(oldArrayProperty);
['push', 'pop', 'shift', 'unshift'].forEach((item) => {arr[item] = function () {// 首先得更新视图updateView();// console.log(JSON.stringify(this)+"88888"); 这里的this表示arr原型上面的知识oldArrayProperty[item].call(this,...arguments)}
})function updateView() {console.log("update");
}// 定义核心Function
function defineReactive1(target, key, value) {// 传过来,继续进行深度监听。observer(value);Object.defineProperty(target, key, {get() {return value;},set(newValue) {if (value != newValue) {// 如果是对象还要继续深度监听observer(newValue);value = newValue;// 通知视图更新。updateView();}}})
}// 遍历属性的api
function observer(target) {// 如果不是对象就返回,这个函数的目的就是深度遍历对象属性。if (typeof target !== 'object' || typeof target === null) {return target;}// 数组的情况if (Array.isArray(target)) {target.__proto__ = arr}// 遍历返回。for (let key in target) {defineReactive1(target, key, target[key]);}}// test
let obj = {name: 'jack',arr:[1,2,3]
}
observer(obj);
obj.name = 'marry';
obj.arr.push(7);
console.log(JSON.stringify(obj));

所以重写数组的基本思路是

  1. 先重写一个原型
  2. 把数组转换为对象。(直接换原型的指向,能够更改)

vue2实现深度监听的缺陷。

  1. 深度监听,需要递归到底,一次计算量大
  2. 无法监听新增属性/删除属性(所以需要使用 Vue.set 和 Vue.delete)
  3. 无法原生监听数组,需要特殊处理

在VUE3中使用proxy深度监听!

也有缺陷,兼容性问题。

上一篇:文件IO常用函数

下一篇:KMP算法原理

相关内容

热门资讯

如何刷一安卓原生系统,安卓原生... 你有没有想过,你的安卓手机其实隐藏着许多未被发掘的潜力?没错,就是那个我们每天不离手的安卓原生系统!...
负信号与系统和安卓,负信号与系... 你知道吗?在科技的世界里,有时候一些看似不起眼的小细节,却能引发一场翻天覆地的变化。今天,咱们就来聊...
安卓系统连接airpods2,... 你有没有想过,你的安卓手机和AirPods 2之间也能来一场甜蜜的“恋爱”呢?没错,就是那种无缝连接...
安卓系统的新版本,功能升级与用... 你知道吗?最近安卓系统又来了一次大变身,新版本一出,瞬间吸引了无数手机控的目光。这不,我就迫不及待地...
安卓系统中英文对,中英文融合的... 你有没有发现,在使用安卓手机的时候,有时候会遇到一些英文提示,让你有点摸不着头脑?别急,今天就来给你...
三星系统和安卓系统版本,系统版... 你有没有发现,手机里的操作系统就像是我们生活中的好朋友,有时候默默无闻,有时候却让我们爱不释手。今天...
安卓系统翻新软件有哪些,重拾流... 手机用久了是不是感觉卡顿得厉害?别急,今天就来给你揭秘安卓系统翻新软件那些事儿!让你的手机焕发第二春...
安卓系统删除动态壁纸,安卓系统... 手机里的动态壁纸是不是已经看腻了?想要给它来个“大变身”,却又不知道怎么下手?别急,今天就来教你怎么...
荣耀安卓系统转苹果,探索苹果生... 你知道吗?最近有个大动作在科技圈里掀起了一阵热潮,那就是荣耀手机用户纷纷将目光投向了苹果阵营。是的,...
安卓系统玩吃鸡平板,体验极致射... 你有没有想过,在平板上也能畅玩吃鸡游戏呢?没错,就是那种随时随地都能开黑的刺激感!今天,就让我带你一...
安卓系统打电话断,探究原因与解... 你是不是也遇到过这种情况?手机屏幕上显示着联系人名字,手指轻轻一点,电话却怎么也打不出去。这可真是让...
安卓平板系统升级关闭,揭秘操作... 亲爱的安卓平板用户们,你们是不是也遇到了这样的烦恼:每次系统升级,都要忍受漫长的等待,甚至有时候升级...
安卓系统怎么修改密码,轻松掌握... 手机里的安卓系统密码忘记了?别急,让我来给你支个招,让你轻松修改密码,重获手机自由! 一、解锁密码的...
优酷对安卓系统要求,揭秘安卓系... 你有没有发现,最近优酷的视频越来越高清了?是不是觉得看视频的体验提升了不少?不过,你知道吗?想要享受...
安卓两个系统切换系统,畅享多系... 你有没有想过,你的安卓手机里竟然可以藏着两个完全不同的系统呢?没错,就是那种一个系统用来工作,另一个...
苹果跟安卓的系统区别 你有没有发现,手机的世界里,苹果和安卓就像是两个截然不同的星球?它们各有各的特色,各有各的粉丝,今天...
安卓系统360抢红包,安卓系统... 你有没有发现,现在不管是聚会还是日常,抢红包已经成了大家不可或缺的娱乐活动呢!而在这其中,安卓系统的...
安卓系统手机wifi连不上wi... 亲爱的手机控们,你是否也有过这样的烦恼:明明家里WiFi信号满格,可就是连不上手机?别急,今天就来帮...
16s安卓系统,创新与变革的科... 你有没有发现,最近你的手机是不是变得越来越流畅了?没错,我要说的就是那个让无数安卓用户心动的16s安...
一加三安卓8.0系统,畅享智能... 你有没有听说最近手机圈里的一股新潮流?那就是一加三安卓8.0系统!这可不是什么小打小闹的更新,而是一...