Vue - 父子組件傳值

導(dǎo)讀 :

Vue中:
1.父組件向子組件傳值:通過給子組件傳遞屬性,子組件通過props接收父組件的值再加以使用。
2.子組件向父組件傳值:通過this.$emit([自定義方法名],[傳遞的參數(shù)1],……)執(zhí)行自定義方法來傳值給父組件轧膘,父組件在方法中接收。

例子:

  • 這是一個通過父子組件傳值來求和的一個例子,每個子組件點擊都會加2攒岛,父組件計算2個子組件和。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script type="text/javascript" src="../vue.js"></script>
</head>
<body>
    <div id="root">
        <!--父組件傳值給子組件通過在子組件中定義屬性如下(:count="0")-->
         <!--子組件傳值給父組件通過執(zhí)行自定義方法-->
        <counter :count="0" @inc='clickChange'></counter>
        <counter :count="1" @inc='clickChange'></counter>
        <div>{{total}}</div>
    </div>
    <script>
        // 通過父組件傳值給子組件胞锰,如果子組件要改變值則會產(chǎn)生警告灾锯,故采用復(fù)制父組件值的方法
        var counter = {
            props: ['count'],
            data: function() {
                return {
                    number: this.count
                }
            },
            template: '<div @click="handleClick">{{number}}</div>',
            methods: {
                handleClick: function() {
                    // console.log(this.number);
                    this.number = this.number + 2;
                    //  給父組件傳值
                    this.$emit('inc', 2);
                }
            }
        };

        // 父組件通過屬性向子組件傳值,
        var vm = new Vue({
            el: '#root',
            components: {
                counter: counter
            },
            data: {
                total: 1
            },
            methods: {
                //  要定義形參來表示接收的值
                clickChange: function(step) {
                    this.total += step;
                }
            }
        })
    </script>
</body>
</html>

總結(jié) :

  • 實際Vue實例也是個組件嗅榕,我們一般稱它為根組件顺饮,若定義局部組件則需要在根組件中聲明,如果是全局組件則不需凌那。
  • 子組件通過父組件傳值的方式拿到的值不可直接進(jìn)行變更兼雄,否則報錯(實際是警告)。結(jié)局辦法:子組件中復(fù)制父組件的值再使用子組件的值即可帽蝶。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末赦肋,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子嘲碱,更是在濱河造成了極大的恐慌金砍,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件麦锯,死亡現(xiàn)場離奇詭異恕稠,居然都是意外死亡,警方通過查閱死者的電腦和手機扶欣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門鹅巍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來千扶,“玉大人,你說我怎么就攤上這事骆捧∨煨撸” “怎么了?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵敛苇,是天一觀的道長妆绞。 經(jīng)常有香客問我,道長枫攀,這世上最難降的妖魔是什么括饶? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮来涨,結(jié)果婚禮上图焰,老公的妹妹穿的比我還像新娘。我一直安慰自己蹦掐,他們只是感情好技羔,可當(dāng)我...
    茶點故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著卧抗,像睡著了一般藤滥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上社裆,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天超陆,我揣著相機與錄音,去河邊找鬼浦马。 笑死,一個胖子當(dāng)著我的面吹牛张漂,可吹牛的內(nèi)容都是我干的晶默。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼航攒,長吁一口氣:“原來是場噩夢啊……” “哼磺陡!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起漠畜,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤币他,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后憔狞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蝴悉,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年瘾敢,在試婚紗的時候發(fā)現(xiàn)自己被綠了拍冠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尿这。...
    茶點故事閱讀 40,144評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖庆杜,靈堂內(nèi)的尸體忽然破棺而出射众,到底是詐尸還是另有隱情,我是刑警寧澤晃财,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布叨橱,位于F島的核電站,受9級特大地震影響断盛,放射性物質(zhì)發(fā)生泄漏罗洗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一郑临、第九天 我趴在偏房一處隱蔽的房頂上張望栖博。 院中可真熱鬧,春花似錦厢洞、人聲如沸仇让。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丧叽。三九已至,卻和暖如春公你,著一層夾襖步出監(jiān)牢的瞬間踊淳,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工陕靠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留迂尝,地道東北人。 一個月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓剪芥,卻偏偏與公主長得像垄开,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子税肪,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,092評論 2 355

推薦閱讀更多精彩內(nèi)容