https://cn.vuejs.org/v2/guide...
這里的示例改成如下:
<style>
#demo,
.demo,
.content .demo {
border: 1px solid rgb(238, 238, 238);
border-radius: 2px;
padding: 25px 35px;
margin-top: 1em;
margin-bottom: 40px;
font-size: 1.2em;
line-height: 1.5em;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
overflow-x: auto;
}
#demo> :first-child,
.demo> :first-child,
.content .demo> :first-child {
margin-top: 0;
}
.dynamic-component-demo-tab-button {
padding: 6px 10px;
border-top-left-radius: 3px;
border-top-right-radius: 3px;
border: 1px solid rgb(204, 204, 204);
cursor: pointer;
background: rgb(240, 240, 240);
margin-bottom: -1px;
margin-right: -1px;
}
.dynamic-component-demo-tab-button-active {
background: rgb(224, 224, 224);
}
</style>
</head>
<body>
<!-- 動(dòng)態(tài)組件 -->
<div id="dynamic-component-demo" class="demo">
<button v-for="tab,index in tabs"
class="dynamic-component-demo-tab-button"
:class="{'dynamic-component-demo-tab-button-active': tab === currentTab }"
@click="currentTab = tab">
{{ tab }}
</button>
<component :is="currentTabComponent" class="dynamic-component-demo-tab">
</component>
</div>
<script type="text/javascript">
var tabHome = {
template: ` <p>Home component </p> `
}
var tabPosts = {
template: ` <p>Posts component </p> `
}
var tabArchive = {
template: ` <p>Archive component </p> `
}
var app = new Vue({
el: "#dynamic-component-demo",
data: {
tabs: ['Home', 'Posts', 'Archive'],
currentTab: 'Home',
},
components: {
"tab-home": tabHome,
"tab-posts": tabPosts,
"tab-archive": tabArchive,
},
computed: {
currentTabComponent: function() {
return 'tab-' + this.currentTab.toLowerCase()
}
}
});
</script>
與原文內(nèi)容不一致的地方是去掉了按鈕上面的
v-bind:key="tab"
通過(guò)hhttps://cn.vuejs.org/v2/guide... 了解到v-for做列表渲染的時(shí)候可以有三個(gè)參數(shù)(value,key,index)分別代表對(duì)象屬性的值,對(duì)象的屬性名和鍵值對(duì)的索引。官網(wǎng)動(dòng)態(tài)組件這里的 tabs: ['Home', 'Posts', 'Archive'], 也只是普通的字符串?dāng)?shù)組。
所以,動(dòng)態(tài)數(shù)組那里 v-bind:key="tab" 有這個(gè)設(shè)定有什么作用。
參考這段文檔:列表渲染 key。Vue 為了節(jié)省資源重復(fù)利用已有 DOM 節(jié)點(diǎn),要求開(kāi)發(fā)者給列表中的元素加上唯一的 key
,這樣在排序之類(lèi)的操作時(shí),就不需要銷(xiāo)毀創(chuàng)建新節(jié)點(diǎn)了。
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥(niǎo)中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。