博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue 计算属性与方法跟侦听器区别(面试考点)
阅读量:5767 次
发布时间:2019-06-18

本文共 1760 字,大约阅读时间需要 5 分钟。

计算属性

模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的。在模板中放入太多的逻辑会让模板过重且难以维护。例如:

{
{ message.split('').reverse().join('') }}
复制代码

在这个地方,模板不再是简单的声明式逻辑。你必须看一段时间才能意识到,这里是想要显示变量 message 的翻转字符串。当你想要在模板中多次引用此处的翻转字符串时,就会更加难以处理。

所以,对于任何复杂逻辑,你都应当使用计算属性。

基础例子

{
{fullName}}
var vm = new Vue({ el: '#app', data: { firstName: "王", lastName: "小智", age: 28 }, // 计算属性 computed: { fullName: function () { console.log("计算了一次") return this.firstName + " " + this.lastName } }})复制代码

结果:

王小智复制代码

然后我们通过浏览器改变age属性的值,让页面重新渲染:

大家可以看到,我们改变了age值计算属性的方法没有被调用,那如果计算属性的值发生了改变,如lastName或者firstName改变,打印结果又会怎么样呢?

大家可以看到,当他依赖的发生变化的时候,计算属性会重新计算一次。

计算属性缓存 vs 方法

你可能已经注意到我们可以通过在表达式中调用方法来达到同样的效果:

Reversed message: "{

{ fullName() }}"

// 在组件中methods: { fullName: function () { console.log("计算了一次") return this.firstName + " " + this.lastName; }}复制代码

结果:

王小智复制代码

同样参照上面,我们通过浏览器改变age属性的值,让页面重新渲染:

可以看出,我们页面只要重新渲染,方法都会执行一次,而计算属性只有在它的相关依赖发生改变时才会重新求值。

我们为什么需要缓存?假设我们有一个性能开销比较大的的计算属性 A,它需要遍历一个巨大的数组并做大量的计算。然后我们可能有其他的计算属性依赖于A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter!如果你不希望有缓存,请用方法来替代。

计算属性 vs 侦听属性

你可能已经注意到我们还可以通过侦听属性达到同样的效果:

var vm = new Vue({  el: '#app',  data: {    firstName: "王",    lastName: "小智",    age: 28,    fullName  },  // 计算属性  watch: {     firstName: function () {        console.log("计算了一次");        this.fullNmae = this.firstName + this.lastName;     },     lastName: function () {        console.log("计算了一次")        this.fullNmae = this.firstName + this.lastName;     }  }})复制代码

结果:

王小智复制代码

同样参照上面,我们通过浏览器改变age属性的值,让页面重新渲染:

大家可以看到,和fullname不相关的改变,fullName没有变化,跟计算属性类似,会有缓存,只有在它的相关依赖发生改变时才会重新求值,将它与计算属性的版本进行比较,好得多了,不是吗?

当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch——特别是如果你之前使用过 AngularJS。然而,通常更好的做法是使用计算属性而不是命令式的 watch 回调。

愿你成为终身学习者

转载地址:http://lfbux.baihongyu.com/

你可能感兴趣的文章
跟我从零基础学习Unity3D开发--初识U3D
查看>>
ubuntu常用配置整理
查看>>
【C语言探索之旅】 第二部分第三课:数组
查看>>
axios升级指南
查看>>
maven 学习笔记
查看>>
MongoDB常用脚本配置方法
查看>>
linux下http配置大全
查看>>
IOS学习之数据库(4)--SQLite的应用
查看>>
keepalived-2-配置文件详解
查看>>
Java NIO 概述
查看>>
015,spring boot集成Jpa
查看>>
Windows小技巧 -- Chrome浏览器中页面保存技巧
查看>>
二叉树链式存储结构(Binary Tree)
查看>>
MySQL高性能的索引策略(二)
查看>>
Oracle 11g RAC开启归档,闪回并设置各自不同的路径
查看>>
晴朗的天空
查看>>
selenium+python自动化测试系列(二):AutoIt工具实现本地文件上传
查看>>
Spring常用注解
查看>>
企业数据安全系统 EMC Retrospect
查看>>
Spring的常用注解
查看>>