vue 中如何检测数组变化

实现数组劫持

数组考虑性能原因没有用defineProperty对数组的每一项进行拦截,而是选择重写数组( push,shift,pop,splice,unshift,sort,reverse) 方法

数组中如果是对象数据类型也会进行递归劫持

核心代码

let obj = {
    name:'jw' , 
    age:30,
    n: {
        num: 000n: [1,2,3,4,5,6]
    }
};

// 创建新的数组的方法
let newArrayProto = Object.create(Array.prototype) 

// 保存老的数组方法
let oldArrayProtot = Array.prototype;

['push','shift','pop','splice','unshift','sort','reverse'].forEach(method=>{
    newArrayProto[method] = function( ...args){
        oldArrayProto[method]。call(this,...args)
    }
})

// 定义相应式函数
function defineReactive(target,key,value){
    // 判断检测对象中是否有嵌套对象
    observer(value)

    object.defineProperty(target, key,{
        get(){
            return value
        },
        set(newValue){
            if(value !== newValue){
                value = newValue;
                // 判断心智是否有是对象
                observer(newValue)
            } 
        } 
    }) 
}

// 定义观察函数
function observer(data){
    // 如果不是对象或者数据为空,直接返回
    if(typeof data !== "object" || typeof data == null){
        return data
    }

    // 判断是否是数组
    if(Array.isArray(data)){
        data.__proto__ = newArrayProto
    } else  for(let key in data){
        // 循环执行第一层数据

        defineReactive(data, key , data[key])
    }
}

observer(obj) 

数组的缺点

数组的索引和长度变化是无法监控到的

更多详细内容,请微信搜索“前端爱好者戳我 查看

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端布道人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值