文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue中使用计算属性的方法是什么

2023-06-21 22:39

关注

这篇文章主要介绍“Vue中使用计算属性的方法是什么”,在日常操作中,相信很多人在Vue中使用计算属性的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue中使用计算属性的方法是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

计算属性

有些时候,我们在模板中放入了过多的逻辑,从而导致模板过重,且难以维护。例如:

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

碰到这样的情况,我们必须看一段时间才能意识到,这里是想要显示变量message的翻转字符串,而且,一旦我们想要在模板中多次使用翻转字符串时,会更加麻烦。 所以,当我们处理复杂逻辑时,都应该使用计算属性。

基础用法

计算属性是Vue配置对象中的属性,使用方式如下:

<div id="app">   <!-- 计算属性的值可以像data数据一样,直接被使用 -->  {{ someComputed }}</div>const vm = new Vue({  el: '#app',  computed: {     // 返回的值,就是计算属性的值    someComputed () {      return 'some values'    }  }})

例如,我们想要获取到一串字符串的翻转字符串,我们可以利用计算属性来做:

<div id="app">  <p>原始字符串: "{{ msg }}"</p>  <p>翻转字符处啊: "{{ reversedMsg }}"</p></div>const vm = new Vue({  el: '#app',  data: {    msg: 'Hello'  },  computed: {    reversedMsg: function () {      return this.msg.split('').reverse().join('');    }  }})

我们可以看到,reversedMsg的值取决于msg的值,所以,当我们更改msg的值是,reversedMsg的值也会随之更改。

计算属性 vs 方法

其实,我们上述的功能,利用方法也可以实现,如:

<div id="app">  <p>原始字符串: "{{ msg }}"</p>  <p>翻转字符串: "{{ reversedMsg() }}"</p></div>const vm = new Vue({  el: '#app',  data: {    msg: 'Hello'  },  methods: {    reversedMsg: function () {      return this.msg.split('').reverse().join('');    }  }})

虽然在表达式中调用方法也可以实现同样的效果,但是使用计算属性和使用方法有着本质的区别。 当使用方法时,每一次页面重新渲染,对应的方法都会重新执行一次,如:

<div id="app">  <p>{{ name }}</p>  <p>{{ reversedMsg() }}</p></div>const vm = new Vue({  el: '#app',  data: {    msg: 'Hello',    name: 'shanshan'  },  methods: {    reversedMsg: function () {      console.log('方法执行啦');      return this.msg.split('').reverse().join('');    }  }})vm.name = 'duyi';

在上面的例子中我们可以看到,一旦更改name的值,页面会重新渲染,此刻控制台中打印出方法执行啦这串字符串,代表着reversedMsg这个函数执行了,但是我们并不需要该方法执行,因为改动的数据和这个函数没有任何关系,如果这个函数内的逻辑很复杂,那么对于性能来讲,也是一种消耗。

但是利用计算属性做,就不会有这样的现象出现,如:

const vm = new Vue({  el: '#app',  data: {    msg: 'Hello',    name: 'shanshan'  },  computed: {    reversedMsg: function () {      console.log('计算执行啦');      return this.msg.split('').reverse().join('');    }  }})vm.name = 'duyi';

此时可以看到,当给数据name重新赋值时,计算属性并没有执行。 所以,计算属性和方法的最本质的区别,是:计算属性是基于响应式依赖进行缓存的,计算属性的值一直存于缓存中,只要它依赖的data数据不改变,每次访问计算属性,都会立刻返回缓存的结果,而不是再次执行函数。而方法则是每次触发重新渲染,调用方法将总会再次执行函数。

那么,为什么需要缓存呢?

假如说,我们有一个计算属性A,它需要遍历一个巨大的数组并且做巨大的计算。然后我们需要使用到这个计算属性A,如果没有缓存,我们就会再次执行A的函数,这样性能开销就变得很大了。

深入计算属性

计算属性除了写成一个函数之外,还可以写成一个对象,对象内有两个属性,getter&setter,这两个属性皆为函数,写法如下:

const vm = new Vue({  el: '#app',  computed: {    fullName: {      getter () {         // 一些代码      },      setter () {         // 一些代码      }    }  }})

getter 读取

在前面,我们直接将计算属性写成了一个函数,这个函数即为getter函数。也就是说,计算属性默认只有getter。 getter的this,被自动绑定为Vue实例。

何时执行?

当我们去获取某一个计算属性时,就会执行get函数。

const vm = new Vue({  el: '#app',  data: {    msg: 'Hello'  },  computed: {    reversedMsg: {      getter () {        return this.msg.split('').reverse().join('');      }    }  }})

setter 设置

可选,set函数在给计算属性重新赋值时会执行。 参数:为被重新设置的值。 setter的this,被自动绑定为Vue实例。

const vm = new Vue({  el: '#app',  data: {    msg: 'Hello',    firstStr: ''  },  computed: {    reversedMsg: {      getter () {        return this.msg.split('').reverse().join('');      },      setter (newVal) {        this.firstStr = newVal[0];      }    }  }})

要注意,即使给计算属性赋了值,计算属性也不会改变,在重复一遍,只有当依赖的响应式属性变化了,计算属性才会重新计算。

练习_姓名筛选

personArr: [  {     name: '',     src: '.jpg',     des: '颈椎不好',     sex: 'm',     id: '056482'  },  {     name: '',     src: '.jpg',     des: '我是谁',     sex: 'f',     id: '157894'  },  {     name: '',     src: '.jpg', des: '我长得很好看',     sex: 'f',     id: '2849245'  },  {     name: '',     src: '.jpeg',     des: '你没有见过陌生的脸',     sex: 'm',     id: '348515'  },  {     name: '',     src: '.jpeg',     des: '瓜皮刘',     sex: 'm',     id: '478454'  }]

练习_全选商品

courseList: [  {    poster: '.jpg',    title: '',    price: 1299,    cart: 1,    id: 0  },  {    poster: '.jpg',    title: '',    price: 1148,    cart: 1,    id: 1595402664708  },  {    poster: '.jpg',    title: '',    price: 1,    cart: 1,    id: 1596305473062  },  {    poster: '.jpg',    title: '',    price: 1,    cart: 1,    id: 1595413512182  },  {    poster: '.jpg',    title: '',    price: 12798,    cart: 1,    id: 1596302161181  },  {    poster: '.jpg',    title: '',    price: 1,    cart: 1,    id: 1596300025301,  },]

知识点扩展:

实例扩展

<div id="app1"></div>    <div id="app2">        {<!-- -->{reverseMes}}    </div>let vm1 = new Vue({            el:'#app1',            data:{                mes:'hello'            }        })        let vm2 = new Vue({            el:'#app2',            computed: {                reverseMes(){                    // 使用实例 vm1中的data数据中心的 mes 去做反转字符串的操作                    return vm1.mes.split('').reverse().join('')                }            }        })

实例vm1中的数据,vm2计算属性也可以使用

自定义的计算属性除了可以在插值表达式中使用,还可以在 v-bind: 属性绑定中使用,用来做一些样式的变换等等。

到此,关于“Vue中使用计算属性的方法是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯