<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>test</title>
<script src="https://unpkg.com/vue@next"></script>
</head>
<body>
<div id="root">
<div>計算屬性:{{total}}</div>
<div>watch監聽:{{newTotal}}</div>
</div>
</body>
<script>
const app = Vue.createApp({
data() {
return {
count: 2,
price: 5,
}
},
watch: {
price(newPrice, oldPrice) {
this.newTotal = newPrice * this.count
}
},
computed: {
total() {
return this.price * this.count
}
},
methods: {
},
});
const vm = app.mount('#root');
</script>
</html>
現在我們改下price的值
結論:
- 只有在監聽到對應的變量改變時,watch纔會執行;