vue.js使用之计算属性与方法返回的差别

<!DOCTYPE html>
<html>
<head>
    <script src="https://unpkg.com/[email protected]"></script>
    <meta charset="utf-8" />
    <title></title>
</head>
<body>
    <div id="app-6">
        <p v-once v-if="see">{{ message }}</p>
        <p   v-if="see">{{ reversedMessage  }}</p>
        <p v-if="see">{{ reversedMessages()  }}</p>

        <input  v-model="message">
        <ol>

            <todo-item
                       v-for="item in groceryList"
                       v-bind:todo="item"
                       v-bind:key="item.id"
                       ></todo-item>

        </ol>
    </div>
</body>
</html>

<script>
    var app6;
    window.onload = function () {

        Vue.component(‘todo-item‘, {
            template: ‘<li>{{todo.text}}</li>‘,
            props:[‘todo‘]
        })
        app6 = new Vue({
            el: ‘#app-6‘,
            data: {
                see: true,
                groceryList: [
                    { id: 0, text: ‘蔬菜‘ },
                    { id: 1, text: ‘奶酪‘ },
                    { id: 2, text: ‘随便其他什么人吃的东西‘ }
                ],

                message: ‘Hello Vue!‘
            },//计算属性
            computed: {
                reversedMessage: function () {
                    return this.message.split(‘‘).reverse().join(‘‘)

                }
            },//方法返回
            methods: {
                reversedMessages: function () {
                    return this.message.split(‘‘).reverse().join(‘‘)

                }
            }

        })
    }

</script>

  注意 由于计算属性与method 与data中的属性都是保存在app6这个对象的一级属性里面 所以如果重名 后定义的将会覆盖前定义的对象

官方文档解释两者的差别

我们可以将同一函数定义为一个 method 而不是一个计算属性。对于最终的结果,两种方式确实是相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

这也同样意味着下面的计算属性将不再更新,因为 Date.now() 不是响应式依赖:


computed: {

now: function () {

return Date.now()

}

}

相比而言,只要发生重新渲染,method 调用总会执行该函数。

文档地址 https://cn.vuejs.org/v2/guide/computed.html

时间: 2024-07-29 18:55:23

vue.js使用之计算属性与方法返回的差别的相关文章

Vue.js 基础学习计算属性computed

我们要写一个成绩表如下 数学 90 物理 80 英语 70 <div id="app"> <table border="1"> <tr> <td>数学</td> <td>{{ math }}</td> </tr> <tr> <td>物理</td> <td>{{ physics }}</td> </tr>

Vue.js系列之四计算属性和观察者

一.计算属性 1.模版内的表达式非常便利,但是设计它们的初衷是用于简单计算的.在模版中放入太多的逻辑运算会让模版过重且难以维护,例如如下代码: <div id="example"> {{ message.split('').reverse().join('') }} </div> 在这个地方,模版不在是简单的声明式逻辑,你必须看一段时间才能意识到,这里是想要显示变量message的翻转字符串,当你想要在模版中多次引用此处的翻转字符串时,就会更加难以处理. 所以,

Vue生命周期,计算属性、方法、侦听器

vue实例和组件都有生命周期函数,beforeCreate()实例或组件没有被创建的时候执行的钩子函数:created()是实例或组件被创建完成的时候执行的钩子函 数:beforeMount()函数是在实例或组件对应虚拟dom触发的钩子函数,此时页面没有内容,mounted编译好的HTML挂载的到页面完成后执行的事件钩子, 此时钩子函数会做一些ajax请求获取数据进行数据初始化,mounted在整个实例中只执行一次,beforeUpdate()更新之前的钩子,实时监控数据变化跟新 dom,upd

vue中计算属性,方法,侦听器

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>vue中计算属性,方法,侦听器</title> <script src="./vue.js"></script> </head> <body> <div id="app&qu

vue中计算属性vs方法的区别

一 什么是计算属性? 计算属性(computed),也是一个属性,也是用来存储数据用的,但是和data属性相比还是有区别 1 数据是可以进行逻辑处理相关的操作 2 可以对计算属性中的数据进行监视 例如: 调用的方式都是一样的 二 计算属性和方法的区别? 1 计算属性是基于它所依赖的数据进行更新,在有在相关依赖的数据发生变化了才会进行更新,而普通的方法每次都会执行 2 计算属性是有缓存的,只要它所依赖的数据没有发生改变,后面的每一次访问计算属性中的值,都是之前缓存的结果,不会重复执行. 例如: h

计算属性和方法

计算属性 computed:{ } 方法 methods: { } 两者功能上差不多,计算属性是基于依赖缓存的,而methods只要页面重新渲染就会变 想做缓存就用计算属性 原文地址:https://www.cnblogs.com/eunuch/p/9812478.html

vue 524 (生命周期 计算属性 监听)

每个 Vue 实例在被创建时都要经过一系列的初始化过程--例如,需要设置数据监听.编译模板.将实例挂载到 DOM 并在数据变化时更新 DOM 等.同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会. 依据上表可以确定各个位置的先后触发顺序 //  关于计算属性: vue改变或获取一个内部方法有以下两种种. 1.在vue对象中 以  methods:{}模式定义各类成员方法: 例如(js  vue对象定义内): methods:{ FF1(){return

计算属性,方法与侦听器

<!DOCTYPE html> <html> <head> <title></title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script src="./vue.js"></script> <!-- <script src="

Vue生命周期、计算属性

一:生命周期 概述: 1.生命周期又叫钩子函数,跟el.data.同级的位置,指的是vue实例从开始创建到最后销毁经历的三阶段,这三个阶段分别叫创建阶段.运行阶段的钩子函数.销毁阶段的钩子函数. 2.其中,三个阶段一共有8个函数 ①创建阶段有四个函数 beforeCreate 实例创建之前 created  实例创建完成 beforeMount 模板挂载之前 mounted   模板挂载之后 ②运行阶段有两个函数 beforeUpdate   视图更新之前 updated 视图更新之后 ③销毁阶