==计算属性在处理一些复杂逻辑时是很有用的==
♦什么是计算属性?
可以对数据进行一些转换后再显示,或者需要将多个数据结合起来进行显示

计算属性关键词:computed

代码示例1

<div id="app">
  {{ message.split('').reverse().join('') }}
</div>

代码示例1中的模板很复杂,且不容易看懂

代码示例2

<div id="app">
  <p>原始字符串: {{ message }}</p>
  <!--错误用法(很容易出错的点,reversedMessage后不能加括号)-->
  <!--<p>{{reversedMessage()}}</p>-->
  <!--正确用法-->
  <p>计算后反转字符串: {{ reversedMessage }}</p>
</div>
 
<script>
var vm = new Vue({
  el: '#app',
  data: {
    message: 'Runoob!'
  },
  // 计算属性的 getter
  computed: {
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
    }
  }
})
</script>

代码示例2中声明了一个计算属性reversedMessage

提供的函数将用作属性 vm.reversedMessage 的 getter 。vm.reversedMessage 依赖 vm.message,在 vm.message 改变时,vm.reversedMessage 也会随之改变

computed和methods对比(了解)

computed和methods的效果一样,区别在于:

  1. computed 是基于它的依赖缓存,只有相关依赖发生改变时才会重新取值。(计算属性多次使用,只会调用一次)
  2. 使用 methods ,在重新渲染的时候,函数总会重新调用执行。(methods执行几次,就调用几次,没有缓存)

代码示例3

<div id="app">
  <!--1.直接拼接:语法过于繁琐-->
  <h2>{{firstName}} {{lastName}}</h2>
  <!--2.通过定义methods-->
  <h2>{{getFullName()}}</h2>
  <h2>{{getFullName()}}</h2>
  <h2>{{getFullName()}}</h2>
  <!--3.通过computed-->
  <h2>{{fullName}}</h2>
  <h2>{{fullName}}</h2>
  <h2>{{fullName}}</h2>

</div>

<script src="../js/vue.js"></script>
<script>
  const app = new Vue({
    el: '#app',
    data: {
      firstName:'Lebron',
      lastName:'James'
    },
    methods: {
      getFullName() {
        console.log('getFullName');//可以在浏览器控制台查看执行3次
        return this.firstName + ' ' + this.lastName
      }
    },
    computed:{
      fullName:function(){
        console.log('getFullName');//可以在浏览器控制台查看执行1次
        return this.firstName+' '+this.lastName
      }
    }
  })
</script>

使用 computed 性能会更好,但是如果不希望缓存,也可以使用 methods 属性。

计算属性的setter和getter

■每一个计算属性都包含一个getter和一个setter
■computed 属性默认只有 getter ,不过在需要时你也可以提供一个 setter

代码示例4

<div id="app">
  <h2>{{fullName}}</h2>
</div>
<script src="../js/vue.js"></script>

<script>
  const app = new Vue({
    el: '#app',
    data: {
      firstName:'Kobe',
      lastName:'Bryant'
    },
    computed:{
     // fullName:function(){
     //   return this.firstname+' '+this.lastName
     // }
     //name:'coderwhy'
      //计算属性一般没有set方法,只读属性
     fullName:{
       set:function(newValue){
         //console.log('----',newValue);
         const names=newValue.split(' ');
         this.firstName=name[0];
         this.lastName=name[1];
       },
       get:function(){
         return this.firstName+' '+this.lastName
       }
     },

      //fullName:function(){
      //  return this.firstName+' '+this.lastName
      //}
    }
  })
</script>

♦Tips

若单词显示如图波浪线,如果检查无误后并且今后还需继续使用该单词,我们可以将该单词加入词库中

在这里插入图片描述
首先选中单词右击鼠标,选择“show Context Actions”

在这里插入图片描述
下一步选择“Save'Lebronb' to dictionary
在这里插入图片描述
最后该单词就被加入词库中,波浪线消失
在这里插入图片描述


oxygen-
4 声望0 粉丝