Vue 計算屬性之姓名案例的三種實現方法

效果:

一、姓名案例-插值語法實現

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Vue初識</title>
    <script type="text/javascript" src="./js/vue.js"></script>
    <style>

    </style>
</head>
<body>
<div id="root">
    姓:<input type="text" v-model="firstName"><br/><br/>
    名:<input type="text" v-model="lastName"><br/><br/>
    全名:<span>{{firstName}}-{{lastName}}</span>
</div>
<script type="text/javascript">
    Vue.config.productionTip = false

    new Vue({
        el:'#root',
        data:{
            firstName:'張',
            lastName:'三'
        }
    })
</script>
</body>
</html>

二、姓名案例-methods實現

數據一發生變化,模板需要重新解析

<div id="root">
    姓:<input type="text" v-model="firstName"><br/><br/>
    名:<input type="text" v-model="lastName"><br/><br/>
    全名:<span>{{fullName()}}</span>
</div>
<script type="text/javascript">
    Vue.config.productionTip = false

    new Vue({
        el: '#root',
        data: {
            firstName: '張',
            lastName: '三'
        },
        methods: {
            fullName() {
                //每次姓或名發生改變,方法都會被調用
                return this.firstName + "-" + this.lastName
            }
        }
    })
</script>

三、姓名案例-計算屬性實現

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Vue初識</title>
    <script type="text/javascript" src="./js/vue.js"></script>
    <style>
    </style>
</head>
<body>
<div id="root">
    姓:<input type="text" v-model="firstName">
    名:<input type="text" v-model="lastName">
    全名:<span>{{fullName}}</span>
</div>
<script type="text/javascript">
    Vue.config.productionTip = false

    const vm = new Vue({
        el: '#root',
        data: {
            firstName: '張',
            lastName: '三'
        },
        computed: {
            fullName: {
                //get()作用:當有人讀取fullName時,get就會被調用,返回值就作為fullName的值
                //get()調用時機:1、初次讀取fullName時。2、所依賴的數據發生變化時
                get() {
                    return this.firstName + "-" + this.lastName
                },
                //set()調用時機:當fullName被修改時
                set(value) {
                    const arr = value.split('-')
                    this.firstName = arr[0]
                    this.lastName = arr[1]
                }
            }
        }
    })
</script>
</body>
</html>

 計算屬性 1、定義:要用的屬性不存在,要通過已有屬性計算得來 2、原理:底層借助瞭objcet.defineproperty方法提供的 getter 和 setter

get 函數什麼時候執行? 1、初次讀取時會執行一次,再讀取計算屬性不會執行,因為有緩存 2、當依賴的數據發生改變時會被再次調用

優勢 與 methods 實現相比,內部有緩存機制(復用),效率更高,調試方便。

備註 1、計算屬性最終會出現在vm上,直接讀取使用即可 2、如果計算屬性要被修改,那必須寫 set 函數去響應修改,且 set 中要引起計算時依賴的數據發生變化

四、計算屬性簡寫

當隻考慮讀取,不考慮修改時,可以使用簡寫形式

<div id="root">
    姓:<input type="text" v-model="firstName"><br/><br/>
    名:<input type="text" v-model="lastName"><br/><br/>
    全名:<span>{{fullName}}</span>
</div>
<script type="text/javascript">
    Vue.config.productionTip = false
    const vm = new Vue({
        el: '#root',
        data: {
            firstName: '張',
            lastName: '三'
        },
        computed: {
            fullName(){
                return this.firstName + "-" + this.lastName
            }
        }
    })
</script>

到此這篇關於Vue 計算屬性之姓名案例的三種實現方法的文章就介紹到這瞭,更多相關Vue 計算屬性 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: