• 售前

  • 售后

热门帖子
入门百科

Vue中的computed属性详解

[复制链接]
諾篱hy 显示全部楼层 发表于 2022-1-8 06:09:16 |阅读模式 打印 上一主题 下一主题
目录


  • 插值表达式
  • methods
  • computed
  • 总结
本日来说说vue中的计算属性computed,为了更好的明确计算属性的好处,我们先通过一个案例来逐步 了解计算属性,有如下案例:定义两个输入框以及一个span标签,span标签中的内容为两个输入框中的值,span标签中的内容随着输入框中的内容变革而变革

插值表达式

我们先用插值表达式的方法来实现这一结果
  1. <body>
  2.     <div id="app">
  3.         姓: <input type="text" v-model=firstName> </br>
  4.         </br>
  5.         名: <input type="text" v-model=lastName></br>
  6.         </br>
  7.         姓名: <span>{{firstName}}{{lastName}}</span>
  8.     </div>
  9. </body>
  10. <script type="text/javascript">
  11.     new Vue({
  12.         el: "#app",
  13.         data: {
  14.             firstName: '张',
  15.             lastName: '三'
  16.         },
  17.         methods: {
  18.         }
  19.     })
  20. </script>
复制代码

我们可以发现能简单实现我们所需要的结果,但是如果现在我想要添加别的的要求,当我输入的是英文的时候就将首字母大写,这个时候我们只能使用以下方法
  1. <body>
  2.     <div id="app">
  3.         firstName: <input type="text" v-model=firstName> </br>
  4.         </br>
  5.         lastName: <input type="text" v-model=lastName></br>
  6.         </br>
  7.         fullName: <span>{{firstName.replace(firstName[0],firstName[0].toUpperCase())}}   {{lastName.replace(lastName[0],lastName[0].toUpperCase())}}</span>
  8.     </div>
  9. </body>
  10. <script type="text/javascript">
  11.     var str = ''
  12.     new Vue({
  13.         el: "#app",
  14.         data: {
  15.             firstName: 'joe',
  16.             lastName: 'lili'
  17.         },
  18.         methods: {
  19.         }
  20.     })
  21. </script>
复制代码

从插值表达式所展现的环境来看固然能实现想要的结果但是代码显得特别冗长倒霉于阅读,这个时候想到可以向methods中添加方法来实现这一结果。

methods

向methods添加fullName方法
  1. <body>
  2.     <div id="app">
  3.         firstName: <input type="text" v-model=firstName> </br>
  4.         </br>
  5.         lastName: <input type="text" v-model=lastName></br>
  6.         </br>
  7.         fullName: <span>{{fullName()}}</span>
  8.     </div>
  9. </body>
  10. <script type="text/javascript">
  11.     var str = ''
  12.     new Vue({
  13.         el: "#app",
  14.         data: {
  15.             firstName: 'joe',
  16.             lastName: 'lili'
  17.         },
  18.         methods: {
  19.             fullName() {
  20.                 let a = '';
  21.                 let b = '';
  22.                 if (this.firstName.length != 0)
  23.                     a = this.firstName.replace(this.firstName[0], this.firstName[0].toUpperCase())
  24.                 if (this.lastName.length != 0)
  25.                     b = this.lastName.replace(this.lastName[0], this.lastName[0].toUpperCase())
  26.                 return a + ' ' + b
  27.             }
  28.         }
  29.     })
  30. </script>
复制代码
我们可以看到通过方法就能很好的解决代码过于冗长的题目。但是又面对了另一个题目,我们在学习vue中的data属性时了解到,只要data中的数据发生变革,页面中用到data数据的地方就会进行更新,以是当data数据firstName与lastName一改变就会重新调用方法fullName,在一定环境下会导致代码服从低,别的,methods中的方法在插值表达式中使用了多少次就会运行多少次。根据以上两种方法的弊端出现了另一种方法,就是使用computed属性。

computed

在computed中可以定义一些属性:计算属性。计算属性的本质其实就是一个方法,只不外在使用的时候可以直接当做属性来使用。详细有以下特点

  • 计算属性在使用时不需要加(),直接写名称即可
  • 如果计算属性用到了data中的数据,当data数据发生变革时,就会立即重新计算这个计算属性的值
  • 计算属性在第一次使用时的结果会被缓存起来,直到属性中所依赖的data数据发生改变计算属性的结果才会重新求值
  1. <body>
  2.     <div id="app">
  3.         firstName: <input type="text" v-model=firstName> </br>
  4.         </br>
  5.         lastName: <input type="text" v-model=lastName></br>
  6.         </br>
  7.         fullName: <span>{{fullName}}</span></br>
  8.         </br>
  9.         fullName: <span>{{fullName}}</span></br>
  10.         </br>
  11.         fullName: <span>{{fullName}}</span>
  12.     </div>
  13. </body>
  14. <script type="text/javascript">
  15.     var str = ''
  16.     new Vue({
  17.         el: "#app",
  18.         data: {
  19.             firstName: 'joe',
  20.             lastName: 'lili'
  21.         },
  22.         computed: {
  23.             //get的作用?当读取fullName时,get就会被调用,且返回值就是fullName的值
  24.             //get什么时候被调用?1.当第一次读取fullName时。2.当所依赖的data数据发生变化时
  25.             fullName: {
  26.                 get() {
  27.                     console.log('hi,我调用了computed')
  28.                   let a = '';
  29.                 let b = '';
  30.                 if (this.firstName.length != 0)
  31.                     a = this.firstName.replace(this.firstName[0], this.firstName[0].toUpperCase())
  32.                 if (this.lastName.length != 0)
  33.                     b = this.lastName.replace(this.lastName[0], this.lastName[0].toUpperCase())
  34.                 return a + ' ' + b
  35.                 }
  36.             }
  37.         }
  38.     })
  39. </script>
  40. </html>
复制代码

在前面我们说过methods中的方法在页面中使用n次便会调用n次,而computed中的属性却不会出现上面的环境。上面代码中我们在页面中使用了同一计算属性3次却只输出了1次结果,同样使用methods中的full方法却输出了3次结果,意味着方法调用了3次。为什么会有如许的结果?这都是因为computed中有缓存机制而methods中并没有。在代码解析到第一个fullName时就会对fullName的结果进行缓存,而到第二个、第三个时会发现缓存中已经有了,那么就不会在对其进行调用。
对computed的使用有了大致的了解后, 我们再来对computed增补一下。
在computed我们可以通过给计算属性添加set方法达到赋值结果
  1. <body>
  2.     <div id="app">
  3.         firstName: <input type="text" v-model=firstName> </br>
  4.         </br>
  5.         lastName: <input type="text" v-model=lastName></br>
  6.         </br>
  7.         fullName: <span>{{fullName}}</span></br>
  8.         </br>
  9.     </div>
  10. </body>
  11. <script type="text/javascript">
  12.     var str = ''
  13.     var app = new Vue({
  14.         el: "#app",
  15.         data: {
  16.             firstName: 'joe',
  17.             lastName: 'lili'
  18.         },
  19.         computed: {
  20.             //get的作用?当读取fullName时,get就会被调用,且返回值就是fullName的值
  21.             //get什么时候被调用?1.当第一次读取fullName时。2.当所依赖的data数据发生变化时
  22.             fullName: {
  23.                 get() {
  24.                     console.log(this)
  25.                     return this.firstName + this.lastName
  26.                 },
  27.                 set(val) {
  28.                     this.firstName = val[0]
  29.                     this.lastName = val[1]
  30.                 }
  31.             }
  32.         }
  33.     })
  34. </script>
复制代码
我们可以看到当在控制台对fullName赋值时firstName以及lastName都会改变
如果计算属性中只有get没有set的话可以直接像下面代码如许写
  1. computed: {
  2.             fullName(){
  3.                 console.log(this)
  4.                 return this.firstName + this.lastName
  5.                 }
  6.             }
复制代码
总结

本篇文章就到这里了,希望能够给你带来资助,也希望您能够多多关注脚本之家的更多内容!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作