vue :計算屬性computed 與方法methods區別


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdn.staticfile.org/vue/2.4.2/vue.min.js"></script>

</head>
<body>
<div id="example">
    <p>{{ nowComputed }}</p>
    <p>{{ nameComputed }}</p>
    <p>{{ ageComputed }}</p>

    <input v-model="name">

    <p>{{ nowMethods() }}</p>
    <p>{{ nameMethods() }}</p>
    <p>{{ ageMethods() }}</p>
</div>
<!--
1.兩者的執行結果是完全相同的
2.計算屬性是基於他們的依賴進行緩存的,只有在相關依賴發生改變時,他們纔會重新求值,
也就是說,只要他的依賴沒有發生變化,那麼每次訪問的時候計算屬性都會立即返回之前的計算結果,不再執行函數
3.每次觸發重新渲染時,調用方法將總會再次執行函數
4.上方兩個例子,計算屬性將總會返回相同值,而方法則不會
-->
<script>
    var vm = new Vue({
        el: '#example',
        data: {
            message: 'Hello',
            name: 'xq',
            age: "16"
        },
        computed: {
            nowComputed: function () {
                console.log("---------------- nowComputed")
                return Date.now()
            },
            nameComputed: function () {
                console.log(this.name + "---------------- nameComputed")
                return "xq nameComputed"
            },
            ageComputed: function () {
                console.log(this.age + "---------------- ageComputed")
                return "18 ageComputed"
            }
        },
        methods: {
            nowMethods: function () {
                console.log("============== nowMethods")
                return Date.now()
            },
            nameMethods: function () {
                console.log(this.name + "============== nameMethods")
                return "xq nameMethods"
            },
            ageMethods: function () {
                console.log(this.age + "============== ageMethods")
                return "18 ageMethods"
            }
        }
    })
</script>

</body>
</html>

初始化:

在這裏插入圖片描述

輸入1 :

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章