监听数组的变化

// 1、定义变量arrayProto接收Array的prototype
// 2、定义变量arrayMethods,通过Object.create()方法继承arrayProto
// 3、重新封装数组中push,pop等常用方法。(这里我们只封装我们需要监听的数组的方法,并不做JavaScript原生Array中原型方法的重写的这么一件暴力的事情)
// 4、其他js数组变化监听方法​
// 1,获得数组的原型
const arrayProto = Array. prototype
const arrayMethods = Object. create( arrayProto)
const newArrProto = []
const method = [
'push',
'pop',
'shift',
'unshift',
'splice',
'sort',
'reverse'
]
method. forEach( function ( method) {
// 原生Array的原型方法
let original = arrayMethods[ method];
// 将push,pop等方法重新封装并定义在对象newArrProto的属性上
// 这里需要注意的是封装好的方法是定义在newArrProto的属性上而不是其原型属性
// newArrProto.__proto__ 没有改变
newArrProto[ method] = function mutator() {
console. log( '监听到数组的变化啦!');

// 调用对应的原生方法并返回结果(新数组长度)
return original. apply( this, arguments);
}

});
// 将我们要监听的数组的原型指针指向上面定义的空数组对象
// newArrProto的属性上定义了我们封装好的push,pop等方法
var list = [ 1, 2]
list. __proto__ = newArrProto;
list. push( 3); // 监听到数组的变化啦! 3

// 这里的list2没有被重新定义原型指针,所以这里会正常执行原生Array上的原型方法
let list2 = [ 1, 2];
list2. push( 3); // 3

// 另外还有es6实现的方式
class NewArray extends Array {
constructor(... args) {
super()
}
push(... args) {
console. log( "监听数组的变化")
return super. push(... args)
}
}

let list3 = [ 1, 2];

let arr = new NewArray(... list3);
console. log( arr)
// (2) [1, 2]

arr. push( 3);
// 监听到数组的变化啦!
console. log( arr)
// (3) [1, 2, 3]

转载于:https://www.cnblogs.com/yayaxuping/p/10951738.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Vue 中,可以使用 `watch` 监听数组变化。但是由于 JavaScript 的限制,使用 `watch` 监听数组变化时只能监听数组的长度变化数组内部元素的引用变化,而不能监听数组内部元素的属性变化。 如果需要监听数组内部元素的属性变化,可以使用 Vue 提供的 `$set` 或者 `splice` 方法来修改数组,并且在修改后使用 `watch` 监听数组变化。 示例代码如下: ```html <template> <div> <ul> <li v-for="(item, index) in list" :key="index">{{ item.title }}</li> </ul> </div> </template> <script> export default { data() { return { list: [ { title: "Vue.js 实战教程" }, { title: "JavaScript 高级编程" }, { title: "Python 基础教程" }, ], }; }, mounted() { // 监听数组变化 this.$watch("list", (newVal, oldVal) => { console.log("list changed:", newVal, oldVal); }, { deep: true }); // 使用 deep 选项可以监听数组内部元素的属性变化 }, methods: { changeTitle(index, newTitle) { // 修改数组内部元素的属性 this.$set(this.list[index], "title", newTitle); }, addBook(title) { // 使用 splice 方法添加新元素 this.list.splice(this.list.length, 0, { title }); }, }, }; </script> ``` 在上面的示例中,我们使用 `$set` 方法来修改了数组内部元素的属性,并使用 `splice` 方法来添加了新元素,然后在 `mounted` 钩子中使用 `watch` 监听数组变化。注意,为了监听数组内部元素的属性变化,我们需要将 `deep` 选项设置为 `true`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值