vue為什么要求組件模板只能有一個(gè)根元素

vue為什么要求組件模板只能有一個(gè)根元素

這個(gè)問題需要從兩個(gè)方面來說起:

1.new Vue({el:'#app'})

2.單文件組件中寓辱,template下的元素div

一、當(dāng)我們實(shí)例化Vue的時(shí)候划提,填寫一個(gè)el選項(xiàng)桨吊,來指定我們的SPA入口:

let vm = new Vue({
  el:'#app'
})

同時(shí)我們也會(huì)在body里面新增一個(gè)id為app的div

<body>
  <div id='app'></div>
</body>

這很好理解车吹,就是為vue開啟一個(gè)入口瞻赶,那我們不妨來想想谆棺,如果我在body下這樣

<body>
  <div id='app1'></div>
  <div id='app2'></div>
</body>

Vue其實(shí)并不知道哪一個(gè)才是我們的入口叹螟,因?yàn)閷?duì)于一個(gè)入口來講魄宏,這個(gè)入口就是一個(gè)‘Vue類'秸侣,Vue需要把這個(gè)入口里面的所有東西拿來渲染,處理宠互,最后再重新插入到dom中味榛。

如果同時(shí)設(shè)置了多個(gè)入口,那么vue就不知道哪一個(gè)才是這個(gè)‘類'予跌。

二搏色、當(dāng)我們?cè)趙ebpack搭建的vue開發(fā)環(huán)境下,使用單文件組件時(shí)券册,你可能會(huì)這樣:

<template> 
  <div class='component'></div>
</template>

那這里為什么template下也必須有且只能有一個(gè)div呢频轿?

這里我們要先看一看template這個(gè)標(biāo)簽垂涯,這個(gè)標(biāo)簽是HTML5出來的新標(biāo)簽,它有三個(gè)特性:

1.隱藏性:該標(biāo)簽不會(huì)顯示在頁面的任何地方航邢,即便里面有多少內(nèi)容耕赘,它永遠(yuǎn)都是隱藏的狀態(tài);

2.任意性:該標(biāo)簽可以寫在頁面的任何地方翠忠,甚至是head鞠苟、body、sciprt標(biāo)簽內(nèi)秽之;

3.無效性:該標(biāo)簽里的任何HTML內(nèi)容都是無效的当娱,不會(huì)起任何作用;

但是呢考榨,你可以通過innerHTML來獲取到里面的內(nèi)容跨细。

知道了這個(gè),我們?cè)賮砜?vue的單文件組件河质。其實(shí)本質(zhì)上冀惭,一個(gè)單文件組件,本質(zhì)上(我認(rèn)為)會(huì)被各種各樣的loader處理成為.js文件(因?yàn)楫?dāng)你import一個(gè)單文件組件并打印出來的時(shí)候掀鹅,是一個(gè)vue實(shí)例)散休,通過template的任意性我們知道,template包裹的HTML可以寫在任何地方乐尊,那么對(duì)于一個(gè).vue來講戚丸,這個(gè)template里面的內(nèi)容就是會(huì)被vue處理為虛擬dom并渲染的內(nèi)容,導(dǎo)致結(jié)果又回到了開始 :既然一個(gè).vue單文件組件是一個(gè)vue實(shí)例扔嵌,那么這個(gè)實(shí)例的入口在哪里限府?

如果在template下有多個(gè)div,那么該如何指定這個(gè)vue實(shí)例的根入口痢缎?

為了讓組件能夠正常的生成一個(gè)vue實(shí)例胁勺,那么這個(gè)div會(huì)被自然的處理成程序的入口。

通過這個(gè)‘根節(jié)點(diǎn)'独旷,來遞歸遍歷整個(gè)vue‘樹'下的所有節(jié)點(diǎn)署穗,并處理為vdom,最后再渲染成真正的HTML势告,插入在正確的位置

那么這個(gè)入口蛇捌,就是這個(gè)樹的‘根',各個(gè)子元素咱台,子組件络拌,就是這個(gè)樹的‘枝葉',而自然而然地回溺,這棵‘樹'春贸,就是指一個(gè)vue實(shí)例了混萝。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市萍恕,隨后出現(xiàn)的幾起案子逸嘀,更是在濱河造成了極大的恐慌,老刑警劉巖允粤,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崭倘,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡类垫,警方通過查閱死者的電腦和手機(jī)司光,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悉患,“玉大人残家,你說我怎么就攤上這事∈墼辏” “怎么了坞淮?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)陪捷。 經(jīng)常有香客問我回窘,道長(zhǎng),這世上最難降的妖魔是什么市袖? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任毫玖,我火速辦了婚禮,結(jié)果婚禮上凌盯,老公的妹妹穿的比我還像新娘。我一直安慰自己烹玉,他們只是感情好驰怎,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著二打,像睡著了一般县忌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上继效,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天症杏,我揣著相機(jī)與錄音,去河邊找鬼瑞信。 笑死厉颤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的凡简。 我是一名探鬼主播逼友,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼精肃,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了帜乞?” 一聲冷哼從身側(cè)響起司抱,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎黎烈,沒想到半個(gè)月后习柠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡照棋,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年资溃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片必怜。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡肉拓,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出梳庆,到底是詐尸還是另有隱情暖途,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布膏执,位于F島的核電站驻售,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏更米。R本人自食惡果不足惜欺栗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望征峦。 院中可真熱鬧迟几,春花似錦、人聲如沸栏笆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛉加。三九已至蚜枢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間针饥,已是汗流浹背厂抽。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留丁眼,地道東北人筷凤。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像户盯,于是被迫代替她去往敵國(guó)和親嵌施。 傳聞我的和親對(duì)象是個(gè)殘疾皇子饲化,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

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

  • 組件簡(jiǎn)介 組件系統(tǒng)是Vue.js其中一個(gè)重要的概念,它提供了一種抽象吗伤,讓我們可以使用獨(dú)立可復(fù)用的小組件來構(gòu)建大型應(yīng)...
    前端一菜鳥閱讀 851評(píng)論 0 16
  • 第一章 Vue概述 what? Vue是實(shí)現(xiàn)UI層的漸進(jìn)式j(luò)s框架吃靠,核心庫關(guān)注視圖層,簡(jiǎn)單的ui構(gòu)建足淆,復(fù)雜的路由控...
    fastwe閱讀 701評(píng)論 0 0
  • Vue組件 vue組件:封裝前端vue特效代碼巢块,便于引用 全局組件全局組件通過Vue.component在scri...
    3e0693dcfb2f閱讀 310評(píng)論 0 0
  • 最近有一部戲,從50后到90后紛紛熱議巧号,微博族奢,朋友圈 ,集體被它刷屏丹鸿。地鐵越走,公交,辦公室里討論的熱氣騰騰靠欢,好像把大...
    折枝春山茶閱讀 276評(píng)論 0 6
  • 一、主從復(fù)制 Redis 的主從復(fù)制特點(diǎn) 1. 配置主從 實(shí)現(xiàn)方式同樣有兩種: 命令方式和配置文件方式 命令方式 ...
    SimmonKuz閱讀 9,315評(píng)論 0 121