js如何实时监听变量的值发生变化?
网友回复
在 JavaScript 中有几种方法可以监听变量的变化。我列举几种常用的方法:
使用 Vue 的 watch(如果在 Vue 项目中):
new Vue({
data: {
someValue: ''
},
watch: {
// 基础监听
someValue(newVal, oldVal) {
console.log('值变化:', oldVal, '->', newVal);
},
// 深度监听对象
someObject: {
handler(newVal, oldVal) {
console.log('对象变化:', oldVal, '->', newVal);
},
deep: true
},
// 立即执行
someData: {
handler(newVal, oldVal) {
console.log('数据变化:', oldVal, '->', newVal);
},
immediate: true
}
}
});
使用 Object.defineProperty(Vue2 的实现原理):
let value = '';
let oldValue = value;
Object.defineProperty(window, 'watchedValue', {
get() {
return value;
},
set(newValue) {
oldValue = value;
value = newValue;
// 值变化时的回调
onValueChange(value, oldValue);
}
});
function onValueChange(newValue, oldValue) {
console.log('值变化:', oldValue, '->', newValue);
}
// 使用
watchedValue = 'new value'; // 会触发 onValueChange
使用 Proxy(Vue3 的实现原理):
const data = {
value: ''
};
const proxy = new Proxy(data, {
get(target, property) {
return target[property];
},
set(target, property, value) {
const oldValue = target[property];
target[property] = value;
// 值变化时的回调
onValueChange(property, value, oldValue);
return true;
}
});
...点击查看剩余70%
claude mythos这么厉害为啥不公开发布给所有人使用?
linux stream如何限制单个目录最大容量?
哪有免费的千问qwen3.6-plus的api可以使用?
python如何自动根据视频图片等素材自动按照要求剪辑视频生成剪映草稿?
gemma4与开源的qwen3.5哪个更厉害?
wan2.7 video与seedance2哪个更好?
claude code 51万行代码泄露被迫开源在哪能找到源码?
有没有免费的虚拟局域网工具可以将互联网设备组成一个大的局域网?
全球顶尖大模型这么强,为啥AGI 测试集体溃败 人类满分 AI 最高仅 0.37%?
听说字节seedance3的视频生成长度可达到10分钟?


