js proxy数据绑定与可观察对象

这篇博客探讨了JavaScript中数据绑定和可观察对象的概念,通过使用Proxy实现了一个简单的用户列表管理,每当有新用户添加时,列表会自动更新。示例展示了如何在构造函数中拦截操作并自动将新实例添加到userList,以及如何在push操作时监听并触发相应事件。
摘要由CSDN通过智能技术生成
// //数据绑定与可观察对象
// const userList = []

// class User {
//     constructor(name) {
//         this._name = name
//     }
// }

// const proxy = new Proxy(User, {
//     construct() {
//         const newUser = Reflect.construct(...arguments)
//         userList.push(newUser)
//         return newUser
//     }
// })

// new proxy('1')
// new proxy('2')
// new proxy('3')

// console.log(userList);

const userList = []
function emit(newValue) {
    // console.log(newValue);
}

const proxy = new Proxy(userList, {
    set(target, property, value, receiver) {
        const result = Reflect.set(...arguments)
        console.log('result', result);
        if (result) {
            emit(Reflect.get(target, property, receiver))
        }
        return result
    }
})

proxy.push('xxx')
proxy.push('yyy')

打印四次

result true
result true
result true
result true

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值