溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue組件之間傳值實力的案例分析

發布時間:2020-08-13 10:16:46 來源:億速云 閱讀:197 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關Vue組件之間傳值實力的案例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

 在我們入門Vue的時候,不得不提到組件,在某些情況下,組件間需要互相傳值,比如父組件需要向子組件傳值,子組件需要向父組件傳值,那么下面用一個實力來詳細說明。

效果:

我們想實現這樣一個效果,在輸入框輸入文字點擊提交按鈕后,下面會出現對應的輸入內容。如果點擊某個內容,那么這個內容就消失。

如下圖,比如我們在點擊2的時候,2就會消失

Vue組件之間傳值實力的案例分析

分析:

1、首先我們會獲取到input的輸入內容,把所有輸入內容都集合成一個數組,在<li><li>循環數據。因為<li><li>都是相同的結構,我們可以把<li><li>做成一個組件,數組是在父層,定義的<li><li>組件是子組件,這就是父組件向子組件傳值,把數據傳給子組件。

2、點擊<li><li>某個選項,該選項會消失。那么<li><li>組件會向上通知父組件,當前點擊的是哪個,需要父層的數組數據中哪個去掉,這就是子組件向父組件傳值。

<div id="root">
        
        <input v-model="inputValue" />
        <button @click="handleSubmit">提交</button>
        
        <ul>
            <todo-item v-bind:content="item" 
                       v-bind:index="index" 
                       v-for="(item,index) in list"
                       @delete="handleItemDelete"
            ></todo-item>
        </ul>
    </div>

    <script>

        var TodoItem={
            props:['content','index'],
            template:"<li @click='handleItemClick'>{{content}}</li>",
            methods:{
                handleItemClick:function(){
                    this.$emit('delete',this.index);
                }
            }
        }

        new Vue({
            el:"#root", 
            data:{
                inputValue:'',
                list:[]
            },
            components:{
                'TodoItem':TodoItem
            },
            methods:{
                handleSubmit:function(){
                    this.list.push(this.inputValue)
                    this.inputValue = ''  //每次提交后清空
                },
                handleItemDelete:function(index){
                    this.list.splice(index,1);
                }
            }
        })
    </script>

通過代碼我們不難發現,子組件向父組件傳值主要在這里:

this.$emit('delete',this.index);

另外需要注意到,在Vue中以$開頭的都叫做vue的實例屬性或者方法,除此之前還需要注意有一些簡寫,比如<button v-on="handleSubmit">提交</button>和<button @click='handleSubmit'>提交</button > 是相同的效果。

關于Vue組件之間傳值實力的案例分析就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女