What are the differences between vue computed properties and watches?
Difference: 1. The calculated attribute needs to be rendered in the template when called, and the metadata on which the calculation depends is modified; watch only needs to modify the metadata when called. 2. Computed attributes default to deep dependence, and watches default to shallow observation. 3. Computed attributes are suitable for filtering and cannot be asynchronous; watch is suitable for asynchronous or expensive operations.
computed
##computed is a computed property, it will be calculated based on the data you rely on Dynamically display new calculation resultsThe calculated properties will be added to the Vue instance. The this context of all getters and settersis automatically bound to the Vue instance
through the calculated propertiesNo need to call Can be used directly in the DOM
Basic example
var vm = new Vue({ el: '#app', data: { message: 'hello' }, template: ` <div> <p>我是原始值: "{{ message }}"</p> <p>我是计算属性的值: "{{ computedMessage}}"</p> // computed 在 DOM 里直接使用不需要调用 </div> `, computed: { // 计算属性的 getter computedMessage: function () { // `this` 指向 vm 实例 return this.message.split('').reverse().join('') } } })
I am the value of the calculated attribute: "olleH"
will have a great impact on the maintainability of the page
And if the calculated attribute If the dependency remains unchanged, it will become a cache, and the computed value will not be recalculated
So, if the data needs to be obtained through complex logic, then it is recommended to use calculated properties
watch
An object, the key is the data corresponding to data, and the value is the corresponding callback function. The value can also be a method name, or an object containing options. When the data data changes, a callback will occur. It has two parameters, a val (modified data data) and an oldVal (original data data). )The Vue instance will call
$watch()when instantiated, traversing each property of the watch object
Basic example
new Vue({ data: { n: 0, obj: { a: "a" } }, template: ` <div> <button @click="n += 1">n+1</button> <button @click="obj.a += 'hi'">obj.a + 'hi'</button> <button @click="obj = {a:'a'}">obj = 新对象</button> </div> `, watch: { n() { console.log("n 变了"); }, obj:{ handler: function (val, oldVal) { console.log("obj 变了") }, deep: true // 该属性设定在任何被侦听的对象的 property 改变时都要执行 handler 的回调,不论其被嵌套多深 }, "obj.a":{ handler: function (val, oldVal) { console.log("obj.a 变了") }, immediate: true // 该属性设定该回调将会在侦听开始之后被立即调用 } } }).$mount("#app");
You should not use the arrow function to define the watcher function, because the arrow function does not have this, and its this will inherit its parent function, but its parent function is window, causing the arrow function to this points to the window, not the Vue instance
- deep controls whether to see the property changes in this object
- immediate controls whether it is the first time Rendering is to execute this function
vm.$watch() The usage is similar to the watch callback
- vm.$watch(' data attribute name', fn, {deep: .., immediate: ..})
vm.$watch("n", function(val, newVal){ console.log("n 变了"); },{deep: true, immediate: true})
The difference between vue calculated properties and watch
Computed properties (computed) | Property detection ( watch) |
Not run for the first time | |
Only need to modify the metadata when calling | |
Default shallow observation | |
Suitable for asynchronous or expensive operations |
Related recommendations:Programming Teaching##2020 Summary of front-end vue interview questions (with answers) vue tutorial recommendation: the latest 5 vue.js video tutorial selections in 2020For more programming-related knowledge, please visit:
The above is the detailed content of What are the differences between vue computed properties and watches?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



The watch option in Vue.js allows developers to listen for changes in specific data. When the data changes, watch triggers a callback function to perform update views or other tasks. Its configuration options include immediate, which specifies whether to execute a callback immediately, and deep, which specifies whether to recursively listen to changes to objects or arrays.

There are three ways to refer to JS files in Vue.js: directly specify the path using the <script> tag;; dynamic import using the mounted() lifecycle hook; and importing through the Vuex state management library.

Using Bootstrap in Vue.js is divided into five steps: Install Bootstrap. Import Bootstrap in main.js. Use the Bootstrap component directly in the template. Optional: Custom style. Optional: Use plug-ins.

You can add a function to the Vue button by binding the button in the HTML template to a method. Define the method and write function logic in the Vue instance.

Vue.js has four methods to return to the previous page: $router.go(-1)$router.back() uses <router-link to="/" component window.history.back(), and the method selection depends on the scene.

Implement marquee/text scrolling effects in Vue, using CSS animations or third-party libraries. This article introduces how to use CSS animation: create scroll text and wrap text with <div>. Define CSS animations and set overflow: hidden, width, and animation. Define keyframes, set transform: translateX() at the beginning and end of the animation. Adjust animation properties such as duration, scroll speed, and direction.

In Vue.js, lazy loading allows components or resources to be loaded dynamically as needed, reducing initial page loading time and improving performance. The specific implementation method includes using <keep-alive> and <component is> components. It should be noted that lazy loading can cause FOUC (splash screen) issues and should be used only for components that need lazy loading to avoid unnecessary performance overhead.

You can query the Vue version by using Vue Devtools to view the Vue tab in the browser's console. Use npm to run the "npm list -g vue" command. Find the Vue item in the "dependencies" object of the package.json file. For Vue CLI projects, run the "vue --version" command. Check the version information in the <script> tag in the HTML file that refers to the Vue file.
