第一个浅度监听:
<!DOCTYPE html>
<html>
<head>
< charset="UTF-8">
< ></ >
< type="text/ " src="js/vue.js"></ >
</head>
<body>
<div id="app">
<p>{{a}}</p>
<p>{{b}}</p>
</div>
< >
var vm=new Vue({
el:"#app",
data:{
a:10,
b:15
}
});
vm.$watch("a",function(){
alert('a变化了');
this.b=100;
});
document. =function(){
vm.a=2
}
</ >
</body>
</html>
第二个深度监听
<!DOCTYPE html>
<html>
<head>
< charset="UTF-8">
< ></ >
< type="text/ " src="js/vue.js"></ >
</head>
<body>
<div id="app">
<p>{{a|json}}</p>
<p>{{b}}</p>
</div>
< >
var vm = new Vue({
el: "#app",
data: {
a: { id: "1", : "width" },
b: 15
}
});
vm.$watch("a", function() {
alert('a变化了');
this.b = 100;
}, { deep: true });
document. = function() {
vm.a.id = "2";
}
</ >
</body>
</html>
ps:下面看下vue中watch用法
对应一个对象,键是观察表达式,值是对应回调。值也可以是方法名,或者是对象,包含选项。在实例化时为每个键调用 $watch() ;
//使用官方vue-cli脚手架书写
<template>
//观察数据为字符串或数组
<input v-model="example0"/>
<input v-model="example1"/>
/当单观察数据examples2为对象时,如果键值发生变化,为了监听到数据变化,需要添加deep:true参数
<input v-model="example2.inner0"/>
</template>
< >
export default {
data(){
return {
example0:"",
example1:"",
example2:{
inner0:1,
innner1:2
}
}
},
watch:{
example0(curVal,oldVal){
console.log(curVal,oldVal);
},
example1:'a',//值可以为methods的方法名
example2:{
//注意:当观察的数据为对象或数组时,curVal和oldVal是相等的,因为这两个形参指向的是同一个数据对象
handler(curVal,oldVal){
conosle.log(curVal,oldVal)
},
deep:true
}
},
methods:{
a(curVal,oldVal){
conosle.log(curVal,oldVal)
}
}
}
</ >
继续阅读与本文标签相同的文章
上一篇 :
java删除指定目录下指定格式文件的方法
-
源码分析ElasticJob选主实现原理
2026-05-17栏目: 教程
-
SpringCloud微服务(06):Config组件,实现配置统一管理
2026-05-17栏目: 教程
-
SpringCloud微服务(07):Zipkin组件,实现请求链路追踪
2026-05-17栏目: 教程
-
阿里云推出高性能一体机POLARDB BOX,全面兼容Oracle、mysql
2026-05-17栏目: 教程
-
利用java反射和java-parser制作可以迭代、分布式、全栈式代码生成器的研究
2026-05-17栏目: 教程
