Vue學(xué)習(xí)之組件用法實(shí)例詳解
本文實(shí)例講述了Vue學(xué)習(xí)之組件用法。分享給大家供大家參考,具體如下:
Vue中的模塊化、可重用代碼塊將頁面細(xì)分為一個個功能組件,而且組件之間可以嵌套。組件分為全局組件與局部組件,局部組件在實(shí)例中進(jìn)行注冊,并且只可以應(yīng)用于該實(shí)例中。
1、 組件的使用流程:
//1、創(chuàng)建組件構(gòu)造器 let overallDiv=Vue.extend({ template:` <div> <p>這是一個全局組件div</p> </div> ` }); //2、注冊全局組件 Vue.component('overall-div',overallDiv); //3、實(shí)例化,組件只有在實(shí)例化的div內(nèi)才能使用,不可以直接在頁面中使用 let vue=new Vue({ el:'#app', data:{}, //在實(shí)例內(nèi)注冊局部組件,其創(chuàng)建與注冊可以合為一步來寫 components:{ 'local-div':{ template: ` <div> <p>這是一個局部組件div</p> </div> ` } }, methods:{ } });
在HTML頁面實(shí)例化的div中使用組件:
<div id="app"> <local-div></local-div> <overall-div></overall-div> </div>
注意:一些HTML標(biāo)簽對放入其中的標(biāo)簽有限制,這時需要通過is屬性將組件轉(zhuǎn)化為你要放入的組件,例如<ul>標(biāo)簽下只能放<li>,這時,你可以使用<li is="my-component">,這樣就相當(dāng)于放入了<my-component>標(biāo)簽。
2、template模板
組件的模板除了在js中創(chuàng)建外,還可以使用頁面中的template創(chuàng)建模板,注意頁面中的模板只能有一個根元素,如有多個元素需要包含在一個div內(nèi),例如頁面body中的模板:
<template id="myTmp"> <div> <p>這是頁面中的模板</p> </div> </template>
在js中通過id號注冊模板。
Vue.component('my-tmp',{ template:'#myTmp' });
3、組件的data
在組件中使用data必須以函數(shù)的形式返回,如果以屬性值的形式存在,所有的組件會共享一個屬性值,更改其中一個,所有的組件都會收到影響。例如一個統(tǒng)計(jì)被點(diǎn)擊次數(shù)的組件:
<template id="myBtn"> <div> <button @click="count++">按鈕被點(diǎn)擊{{count}}次</button> </div> </template>
Vue.component('my-btn',{ template:'#myBtn', data () { //以函數(shù)返回的方式定義組件使用的data return { count:0 }; } }); <div id="app"> <my-btn></my-btn> <my-btn></my-btn> </div>
在頁面中分別點(diǎn)擊兩個按鈕,兩個按鈕組件的count分別計(jì)數(shù),不會互相干擾:
4、父子組件
先創(chuàng)建子組件,然后再父組件內(nèi)進(jìn)行注冊,就可以在父組件的模板內(nèi)使用子組件,然后再注冊父組件,這樣就可以在外部調(diào)用包含子組件的父組件了,外部直接使用父組件接口,而不需要知道內(nèi)部子組件的實(shí)現(xiàn)
注意在外部不能直接使用子組件,因?yàn)樗辉诟附M件內(nèi)進(jìn)行了注冊,外部看不到子組件
let child1=Vue.extend({ template:`<div>這是子組件1</div>` }); let child2=Vue.extend({ template:`<div>這是子組件2</div>` }); Vue.component('parent',{ components:{ 'c1':child1, 'c2':child2 }, //在父組件內(nèi)調(diào)用子組件 template:`<div>父組件<c1></c1><c2></c2></div>` }); <div id="app"> <parent></parent> </div>
結(jié)果如圖:
5、插槽slot
像生活中的容器一樣,slot允許向其中插入標(biāo)簽、組件等內(nèi)容,而在外部提供一個框子包裝起來。slot分為匿名插槽與實(shí)名插槽,匿名插槽可以向其中插入任何類型的內(nèi)容。
實(shí)名slot可以將內(nèi)容插入指定的插槽內(nèi),就像一臺電腦的主板,cpu、內(nèi)存條分別有自己對應(yīng)的插槽,實(shí)名插槽在模板中通過name屬性規(guī)定插槽的名字,在使用時,通過標(biāo)簽的slot屬性指定對應(yīng)的name,可以將標(biāo)簽插入指定的插槽。
匿名插槽
<!--匿名插槽--> <template id="anonymousDiv"> <div style="width: 20%;"> <h3>這是插槽頭部</h3> <slot>插槽默認(rèn)顯示內(nèi)容</slot> <hr/> <p>插槽尾部</p> </div> </template> let vue2=new Vue({ el:'#app2', data:{ }, components:{ //綁定匿名插槽 'anonymous-slot':{ template:'#anonymousDiv' }, //綁定實(shí)名插槽 'realname-slot':{ template:'#realnameDiv' } } });
向cpu插槽內(nèi)插入內(nèi)容:
<div id="app2"> <anonymous-slot> <p>向插槽中插入一段文字</p> </anonymous-slot> </div>
插槽未放入內(nèi)容時:插入一段文字:
實(shí)名插槽
<template id="realnameDiv"> <div> <h3>實(shí)名插槽頭部</h3> <slot name="cpu">這是cpu插槽</slot> <slot name="memery">這是內(nèi)存條插槽</slot> <slot name="HardDisk">這是硬盤插槽</slot> </div> </template> <realname-slot> <p slot="cpu">Intel Core i5</p> </realname-slot>
結(jié)果:cpu放入指定插槽,而其他插槽未受影響:
希望本文所述對大家vue.js程序設(shè)計(jì)有所幫助。
上一篇:Node中對非阻塞I/O、事件循環(huán)的知識點(diǎn)總結(jié)
欄 目:JavaScript
下一篇:原生js實(shí)現(xiàn)文件上傳、下載、封裝等實(shí)例方法
本文標(biāo)題:Vue學(xué)習(xí)之組件用法實(shí)例詳解
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9296.html
您可能感興趣的文章
- 01-10在Vue項(xiàng)目中使用Typescript的實(shí)現(xiàn)
- 01-10Vue中使用Lodop插件實(shí)現(xiàn)打印功能的簡單方法
- 01-10Vue filter 過濾當(dāng)前時間 實(shí)現(xiàn)實(shí)時更新效果
- 01-10Vuex實(shí)現(xiàn)數(shù)據(jù)共享的方法
- 01-10Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞操作實(shí)例分析
- 01-10vue中根據(jù)時間戳判斷對應(yīng)的時間(今天 昨天 前天)
- 01-10Vue+Node實(shí)現(xiàn)的商城用戶管理功能示例
- 01-10vue實(shí)現(xiàn)拖拽效果
- 01-10vue圖片上傳組件使用詳解
- 01-10vue項(xiàng)目實(shí)現(xiàn)圖片上傳功能


閱讀排行
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10使用C語言求解撲克牌的順子及n個骰子