提示

本文主要讲解 Vue 中的计算属性。@ermo

# 计算属性

计算属性的关键词是 computed,用于数据的简单计算,避免模板因为冗余的计算公式而变得臃肿。

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

上面这个例子需要将 message 进行加工,可以通过表达式实现。

也可以通过计算属性实现。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>
    <div id="app">
        <p>{{ message.split('').reverse().join('') }}</p>

        <p>原消息:{{message}}</p>
        <p>翻转后的消息:{{reverseMsg}}</p>
    </div>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                message: 'ermo.cc'
            },
            computed: {
                reverseMsg: function() {
                    return this.message.split('').reverse().join('')
                }
            }
        });
    </script>
</body>
</html>

通过方法功能也可以实现对数据的加工。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>
    <div id="app">
        <p>{{ reverseMsg() }}</p>
    </div>
    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                message: 'ermo.cc'
            },
            methods: {
                reverseMsg: function() {
                    return this.message.split('').reverse().join('');
                }
            }
        });
    </script>
</body>
</html>

计算属性 computedmethods 的区别是前者有缓存,在大量数据加工的情况下,只有相关响应式依赖发生改变才会重新求值。

computed: {
    now: function() {
        return Date.now();
    }
}

上例中计算属性值 now 不依赖绑定数据,所以不会发生改变。

# set 方法

计算属性默认有提供 get 方法,如果需要用到 set 方法,可以进行自定义。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2.7.14"></script>
</head>
<body>

    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                name: 'Google',
                url: 'https://google.com'
            },
            computed: {
                site: {
                    get: function() {
                        return this.name + ' ' + this.url;
                    },
                    set: function(newValue) {
                        var arr = newValue.split(' ');
                        this.name = arr[0];
                        this.url = arr[arr.length - 1];
                    }
                }
            }  
        });

        vm.site = '二默 https://ermocc';
        document.write('网站名:' + vm.name);
        document.write('<br/>')
        document.write('网站地址:' + vm.url);
    </script>

</body>
</html>
上次更新: 2/20/2023, 6:45:13 AM