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


    <!DOCTYPE html>
    <html>
    <head>
        <script src="https://unpkg.com/vue@2.4.2"></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

  • 相关阅读:
    MVC知识总结(前序)
    MySql 安装
    django【ORM】model字段类型
    gmail注册时“此电话号码无法用于进行验证”
    Python3 re模块正则表达式中的re.S
    django【ORM】 通过外键字段找对应类
    Django【进阶】modelform
    python3-字符编码
    python3-可变和不可变数据类型
    Django【设计】同功能不同实现模式的兼容性
  • 原文地址:https://www.cnblogs.com/ProDoctor/p/7399922.html
Copyright © 2020-2023  润新知