This time I will bring you vue calculationpropertiesand listener case code analysis, what are thenotesfor implementing vue calculation properties and listeners, the following is a practical case, one Get up and take a look.
Basic example
Original message: "{{ message }}"
Computed reversed message: "{{ reversedMessage }}"
var vm = new Vue({ el: '#example', data: { message: 'Hello' }, computed: { // 计算属性的 getter reversedMessage: function () { // `this` 指向 vm 实例 return this.message.split('').reverse().join('') } } })
Result:
##Original message: "Hello"Here we declare a calculated property reversedMessage. The function we provide will be used as the getter function of the property vm.reversedMessage:Computed reversed message : "olleH"
console.log(vm.reversedMessage) // => 'olleH' vm.message = 'Goodbye' console.log(vm.reversedMessage) // => 'eybdooG'
vm.reversedMessagealways depends on the value of vm.message.
vm.reversedMessagedepends on vm.message, so when vm.message changes, all bindings that depend on vm.reversedMessage are also updated. And the best part is that we've created this dependency in a declarative way: the computed property's getter function has no side effects, making it easier to test and understand
Computation Property caching vs methods
You may have noticed that we can achieve the same effect by calling a method in anexpression:
Reversed message: "{{ reversedMessage() }}"
// 在组件中 methods: { reversedMessage: function () { return this.message.split('').reverse().join('') } }
computed: { now: function () { return Date.now() } }
Computed properties vs listening properties
Vue provides a more general way to observe and respond to data changes on Vue instances: listening properties. When you have some data that needs to change when other data changes, it's easy to abuse watches - especially if you've used{{ fullName }}
var vm = new Vue({ el: '#demo', data: { firstName: 'Foo', lastName: 'Bar', fullName: 'Foo Bar' }, watch: { firstName: function (val) { this.fullName = val + ' ' + this.lastName }, lastName: function (val) { this.fullName = this.firstName + ' ' + val } } })
var vm = new Vue({ el: '#demo', data: { firstName: 'Foo', lastName: 'Bar' }, computed: { fullName: function () { return this.firstName + ' ' + this.lastName } } })
Setters for computed properties
Computed properties only have getters by default, but you can also provide a setter when needed:// ... computed: { fullName: { // getter get: function () { return this.firstName + ' ' + this.lastName }, // setter set: function (newValue) { var names = newValue.split(' ') this.firstName = names[0] this.lastName = names[names.length - 1] } } } // ...
When vm.fullName = 'John Doe', the setter will be called, and vm.firstName and vm.lastName will be updated accordingly.
Listener
While computed properties are more appropriate in most cases, sometimes a custom listener is needed. This is why Vue provides a more general way to respond to changes in data through the watch option. This approach is most useful when you need to perform asynchronous or expensive operations when data changes. For example:
Ask a yes/no question:
{{ answer }}
Ask a yes/no question: I cannot give you an answer until you ask a question !In this example, using the watch option allows us to perform an asynchronous operation (access an API), limit how often we perform the operation, and set an intermediate
before we get the final result state. These are things that computed properties cannot do.
In addition to the watch option, you can also use the imperative vm.$watch API.
I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!
Recommended reading:
Detailed explanation of the steps to use vuex and components together
Vue uses vux-ui custom form verification attention What are the matters
The above is the detailed content of Vue computed properties and listener case code analysis. For more information, please follow other related articles on the PHP Chinese website!