怎样使用vue计算属性与方法侦听器

这次给大家带来怎样使用vue计算属性与方法侦听器,使用vue计算属性与方法侦听器的注意事项有哪些,下面就是实战案例,一起来看一下。

计算属性

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

{{ 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属性的值,让页面重新渲染:

怎样使用vue计算属性与方法侦听器

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

怎样使用vue计算属性与方法侦听器

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

计算属性缓存 vs 方法

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

reversed message: "{{ fullname() }}"

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

登录后复制

结果:

王小智

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

怎样使用vue计算属性与方法侦听器

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

我们为什么需要缓存?假设我们有一个性能开销比较大的的计算属性 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属性的值,让页面重新渲染:

怎样使用vue计算属性与方法侦听器

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

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

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

怎样进行vue.js登录控制

怎样使用JS获取DOM 元素绝对位置

立即学习“前端免费学习笔记(深入)”;

以上就是怎样使用vue计算属性与方法侦听器的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2750928.html

(0)
上一篇 2025年3月8日 05:44:49
下一篇 2025年3月8日 05:44:58

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 在vue中如何实现自定义全局方法

    下面我就为大家介绍一下vue 自定义全局方法,在组件里面的使用。具有很好的参考价值,希望对大家有所帮助。 在main.js里进行全局注册 Vue.prototype.funcName = function (){} 登录后复制 在所有组件里…

    编程技术 2025年3月8日
    200
  • 在Vue组件中如何使用 TypeScript的方法(详细教程)

    typescript不仅可以约束我们的编码习惯,还能起到注释的作用,当我们看到一函数后我们立马就能知道这个函数的用法。这篇文章主要介绍了在vue组件中使用 typescript的方法,需要的朋友可以参考下 注意:此文并不是把vue改为全部替…

    2025年3月8日 编程技术
    200
  • js 数组操作与解析方法汇总

    这次给大家带来js 数组操作与解析方法汇总,js数组操作与解析的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 在开发中,数组的使用场景非常多,平日中也涉及到很多数组的api/相关操作,一直也没有对这块内容进行一块整理总结,很多时候…

    编程技术 2025年3月8日
    200
  • web开发中怎样检测属性

    这次给大家带来web开发中怎样检测属性,web开发中检测属性的注意事项有哪些,下面就是实战案例,一起来看一下。 用到null(以及undefined)的场景是当检测一个属性是否在对象中存在时,比如: // 不好的写法:检测假值if (obj…

    编程技术 2025年3月8日
    200
  • 维护JS代码的三种方法

    这次给大家带来维护JS代码的三种方法,维护JS代码的注意事项有哪些,下面就是实战案例,一起来看一下。 维护。在其他语言中,考虑将已存在的对象作为库用来完成开发任务。在JS中,我们可以将已存在的对象视为一种背景,在这之上可以做任何事情。你应该…

    编程技术 2025年3月8日
    200
  • 如何访问JS的对象属性与方法

    这次给大家带来如何访问JS的对象属性与方法,访问JS对象属性与方法的注意事项有哪些,下面就是实战案例,一起来看一下。 定义一个对象,然后用点运算符(.)来访问属性和方法。今天突然看见还有另外一种方法中括号运算符([]),就认真看了下。 va…

    2025年3月8日 编程技术
    200
  • 在vue中使用echarts3.0自适应的方法有哪些?

    这篇文章主要介绍了vue中echarts3.0自适应,现在分享给大家,也给大家做个参考。 前端时间做一个vue的项目,echart是按需引入的如下: // 引入 ECharts 主模块import echarts from ‘echarts…

    编程技术 2025年3月8日
    200
  • jQuery和ajax实现鼠标单击修改内容的方法

    这篇文章主要介绍了jquery+ajax实现鼠标单击修改内容的方法,需要的朋友可以参考下 现有表格中的一行的代码如下所示:   2 公司介绍 内部栏目 2登录后复制 要实现鼠标单击修改内容思路如下: 1、点击栏目排序栏目中的数字,获取同一行…

    编程技术 2025年3月8日
    200
  • js如何处理剪贴板的内容?js处理剪贴板的内容的方法

    本篇文章给大家带来的内容是关于js如何处理剪贴板的内容?js处理剪贴板的内容的方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 在学习这个知识点之前需要了解的是: 在网页中一般是不允许访问“剪贴板”的,因为这样存在着很大…

    编程技术 2025年3月8日
    200
  • 如何在 JavaScript 中获取 CSS 值?有什么方法

    本篇文章给大家带来的内容是关于如何在 javascript 中获取 css 值?有什么方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 有时候单独的使用CSS是不够的。您可能需要使用JavaScript控制CSS值。但是…

    2025年3月8日
    200

发表回复

登录后才能评论