亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vuejs第十三篇之組件——雜項

 更新時間:2016年09月09日 10:01:07   作者:qq20004604  
組件(Component)是 Vue.js 最強(qiáng)大的功能之一。本文重點給大家介紹vuejs組件相關(guān)知識,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧

什么是組件?

組件(Component)是 Vue.js 最強(qiáng)大的功能之一。組件可以擴(kuò)展 HTML 元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能。在有些情況下,組件也可以是原生 HTML 元素的形式,以 is 特性擴(kuò)展。

本篇資料是小編參考官方文檔的基礎(chǔ)上整理的一篇更加細(xì)致的說明,代碼更多更全,非常適合新手學(xué)習(xí)。

官方文檔:

http://cn.vuejs.org/guide/components.html#u52A8_u6001_u7EC4_u4EF6

組件——雜項詳細(xì)介紹如下所示:

①組件和v-for

簡單來說,就是組件被多次復(fù)用;

例如表格里的某一行,又例如電商的商品櫥窗展示(單個櫥窗),都可以成為可以被復(fù)用的組件;

只要編寫其中一個作為組件,然后使數(shù)據(jù)來源成為一個數(shù)組(或?qū)ο?,但個人覺得最好是數(shù)組),通過v-for的遍歷,組件的每個實例,都可以獲取這個數(shù)組中的一項,從而生成全部的組件。

而數(shù)據(jù)傳輸,由于復(fù)用,所以需要使用props,將遍歷結(jié)果i,和props綁定的數(shù)據(jù)綁定起來,綁定方法同普通的形式,在模板中綁定。

示例代碼:

<div id="app"> 
<button @click="toknowchildren">點擊讓子組件顯示</button> 
<table> 
<tr> 
<td>索引</td> 
<td>ID</td> 
<td>說明</td> 
</tr> 
<tr is="the-tr" v-for="i in items" v-bind:id="i" :index="$index"></tr> 
</table> 
</div> 
<script> 
var vm = new Vue({ 
el: '#app', 
data: { 
items: [1, 2, 3, 4] 
}, 
methods: { 
toknowchildren: function () { //切換組件顯示 
console.log(this.$children); 
} 
}, 
components: { 
theTr: { //第一個子組件 
template: "<tr>" + 
"<td>{{index}}</td>" + 
"<td>{{id}}</td>" + 
"<td>這里是子組件</td>" + 
"</tr>", 
props: ['id','index'] 
} 
} 
}); 
</script> 

說明:

【1】記得將要傳遞的數(shù)據(jù)放在props里!

【2】將index和索引$index綁定起來,因為索引從0開始,因此索引所在列是從0開始;id是和遍歷items的i綁定在一起的,因此id從1開始。

【3】可以在父組件中,通過this.$children來獲取子組件(但是比較麻煩,特別是組件多的時候,比較難定位);

②編寫可復(fù)用的組件:

簡單來說,一次性組件(只用在這里,不會被復(fù)用的)跟其他組件緊密耦合是可以的,但是,可復(fù)用的組件應(yīng)當(dāng)定義一個清晰的公開接口。(不然別人怎么用?)

可復(fù)用的組件,基本都是要和外部交互的,而一個組件和外部公開的交互接口有:

【1】props:允許外部環(huán)境數(shù)據(jù)傳遞給組件;

【2】事件:允許組件觸發(fā)外部環(huán)境的action,就是說通過在掛載點添加v-on指令,讓子組件的events觸發(fā)時,同時觸發(fā)父組件的methods;

【3】slot:分發(fā),允許將父組件的內(nèi)容插入到子組件的視圖結(jié)構(gòu)中。

如代碼:

<div id="app"> 
<p>這是第一個父組件</p> 
<widget 
:the-value="test" 
@some="todo"> 
<span>【第一個父組件插入的內(nèi)容】</span> 
</widget> 
</div> 
<div id="app2"> 
<p>這是第二個父組件</p> 
<widget @some="todo"> 
</widget> 
</div> 
<script> 
Vue.component("widget", { 
template: "<button @click='dosomething'><slot></slot>這是一個復(fù)用的組件,點擊他{{theValue}}</button>", 
methods: { 
dosomething: function () { 
this.$emit("some"); 
} 
}, 
events: { 
some: function () { 
console.log("widget click"); 
} 
}, 
props: ['theValue'] 
}) 
var vm = new Vue({ 
el: '#app', 
data: { 
test: "test" 
}, 
methods: { 
todo: function () { 
console.log("這是第一個父組件") 
} 
} 
}); 
var vm_other = new Vue({ 
el: '#app2', 
data: { 
name: "first" 
}, 
methods: { 
todo: function () { 
console.log("這是另外一個父組件") 
} 
} 
}); 
</script> 

說明:

【1】在第一個父組件中使用了分發(fā)slot,使用了props來傳遞值(將test的值傳到子組件的theValue之中);

【2】在兩個組件中,子組件在點擊后,調(diào)用methods里的dosomething方法,然后執(zhí)行了events里的some事件。又通過掛載點的@some=”todo”,將子組件的some事件和父組件的todo方法綁定在一起。

因此,點擊子組件后,最終會執(zhí)行父組件的todo方法。

【3】更改父組件中,被傳遞到子組件的值,會同步更改子組件的值(即二者會數(shù)據(jù)綁定);

③異步組件:

按照我的理解,簡單來說,一個大型應(yīng)用,他有多個組件,但有些組件無需立即加載,因此被分拆成多個組件(比如說需要立即加載的,不需要立即加載的);

需要立即加載的,顯然放在同一個文件中比較好(或者同一批一起請求);

而不需要立即加載的,可以放在其他文件中,但需要的時候,再ajax向服務(wù)器請求;

這些后續(xù)請求的呢,就是異步組件;

做到這種異步功能的,就是Vue.js的功能——允許將組件定義為一個工廠函數(shù),動態(tài)解析組件的定義。

可以配合webpack使用。

至于如何具體使用,我還不太明白,教程中寫的不清,先擱置等需要的時候來研究。

鏈接:

http://cn.vuejs.org/guide/components.html#u5F02_u6B65_u7EC4_u4EF6

④資源命名的約定:

簡單來說,html標(biāo)簽(比如div和DIV是一樣的)和特性(比如要寫成v-on這樣的指令而不是vOn)是不區(qū)分大小寫的。

而資源名往往是寫成駝峰式(比如camelCase駝峰式),或者單詞首字母都大寫的形式(比如PascalCase,我不知道該怎么稱呼這個,不過這樣寫很少的說)。

Vue.component("myTemplate", {
//......略
})

Vue.js可以自動識別這個并轉(zhuǎn)換,

<my-template></my-template>

以上那個模板可以自動替換這個標(biāo)簽。

⑤遞歸組件:

簡單來說,遞歸組件就是組件在自己里內(nèi)嵌自己的模板。

組件想要遞歸,需要name屬性,而Vue.component自帶name屬性。

大概樣子是這樣的,

<div id="app"> 
<my-template></my-template> 
</div> 
<script> 
Vue.component("myTemplate", { 
template: "<p><my-template></my-template></p>" 
}) 

這種是無限遞歸,肯定是不行的。因此,需要控制他遞歸的層數(shù),例如通過數(shù)據(jù)來控制遞歸,當(dāng)數(shù)據(jù)為空時,則停止遞歸。

示例代碼如下:

<ul id="app"> 
<li> 
{} 
</li> 
<my-template v-if="a" :a="a.a" :b="a.b"></my-template> 
</ul> 
<script> 
Vue.component("myTemplate", { 
template: '<ul><li>{}</li><my-template v-if="a" :a="a.a" :b="a.b"></my-template></ul>', 
props: ["a", "b"] 
}) 
var data = { 
a: { 
a: { 
a: 0, 
b: 3 
}, 
b: 2 
}, 
b: 1 
} 
var vm = new Vue({ 
el: '#app', 
data: data, 
methods: { 
todo: function () { 
this.test += "!"; 
console.log(this.test); 
} 
} 
}); 
</script> 

說明:

【1】向下傳遞時,通過props傳遞a的值和b的值,其中a的值作為遞歸后組件的a和b的值的數(shù)據(jù)來源;
然后判斷傳遞到遞歸后的組件的a的值是否存在,如果存在則繼續(xù)遞歸;
如果a的值不存在,則停止遞歸。

⑥片斷實例:

簡單來說,所謂片斷實例,就是組件的模板不是處于一個根節(jié)點之下:

片斷實例代碼:

Vue.component("myTemplate", { 
template: '<div>1</div>' + 
'<div>2</div>', 
}) 

非片斷實例:

Vue.component("myTemplate", { 
template: '<div>' + 
'<div>1</div>' + 
'<div>2</div>' + 
'</div>', 
}) 

片斷實例的以下特性被忽略:

【1】組件元素上的非流程控制指令(例如寫在掛載點上的,由父組件控制的v-show指令之類,但注意,v-if屬于流程控制指令);

【2】非props特性(注意,props不會被忽略,另外props是寫在掛載點上的);

【3】過渡(就是transition這個屬性,將被忽略);

更多的參照官方文檔:

http://cn.vuejs.org/guide/components.html#u7247_u65AD_u5B9E_u4F8B

⑦內(nèi)聯(lián)模板

參照:http://cn.vuejs.org/guide/components.html#u5185_u8054_u6A21_u677F

以上所述是小編給大家介紹的Vuejs第十三篇之組件——雜項,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue中點擊按鈕下載文件的實現(xiàn)方式

    vue中點擊按鈕下載文件的實現(xiàn)方式

    這篇文章主要介紹了vue中點擊按鈕下載文件的實現(xiàn)方式,具有很的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 關(guān)于Vue 3.0引入百度地圖不兼容的解決辦法

    關(guān)于Vue 3.0引入百度地圖不兼容的解決辦法

    這篇文章主要介紹了關(guān)于Vue 3.0引入百度地圖不兼容的解決辦法,本文通過實例代碼給大家分享解決方法,需要的朋友可以參考下
    2022-08-08
  • Vue實現(xiàn)base64編碼圖片間的切換功能

    Vue實現(xiàn)base64編碼圖片間的切換功能

    這篇文章主要介紹了Vue實現(xiàn)base64編碼圖片間的切換功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • vite搭建vue2項目的實戰(zhàn)過程

    vite搭建vue2項目的實戰(zhàn)過程

    自從體驗了一下vite之后,真的太快了,然而對vue3還不是很熟練,就想著在vue2的項目中使用以下vite,下面這篇文章主要給大家介紹了關(guān)于vite搭建vue2項目的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • Vue.use()的用法和install的用法解析

    Vue.use()的用法和install的用法解析

    這篇文章主要介紹了Vue.use()的用法和install的用法解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 如何在Vue單頁面中進(jìn)行業(yè)務(wù)數(shù)據(jù)的上報

    如何在Vue單頁面中進(jìn)行業(yè)務(wù)數(shù)據(jù)的上報

    為什么要在標(biāo)題里加上一個業(yè)務(wù)數(shù)據(jù)的上報呢,因為在咱們前端項目中,可上報的數(shù)據(jù)維度太多,比如還有性能數(shù)據(jù)、頁面錯誤數(shù)據(jù)、console捕獲等。這里我們只講解業(yè)務(wù)數(shù)據(jù)的埋點。
    2021-05-05
  • vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    vue實現(xiàn)動態(tài)路由的方法及路由原理解析

    這篇文章主要介紹了路由原理及vue實現(xiàn)動態(tài)路由,Vue Router 提供了豐富的 API,可以輕松地實現(xiàn)路由功能,并支持路由參數(shù)、查詢參數(shù)、命名路由、嵌套路由等功能,可以滿足不同應(yīng)用程序的需求,需要的朋友可以參考下
    2023-06-06
  • 解決Vue+Electron下Vuex的Dispatch沒有效果問題

    解決Vue+Electron下Vuex的Dispatch沒有效果問題

    這篇文章主要介紹了Vue+Electron下Vuex的Dispatch沒有效果的解決方案 ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • Vue實現(xiàn)hash模式網(wǎng)址方式(就是那種帶#的網(wǎng)址、井號url)

    Vue實現(xiàn)hash模式網(wǎng)址方式(就是那種帶#的網(wǎng)址、井號url)

    這篇文章主要介紹了Vue實現(xiàn)hash模式網(wǎng)址方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue 集成jTopo 處理方法

    vue 集成jTopo 處理方法

    這篇文章主要介紹了vue 集成jTopo 處理方法,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-08-08

最新評論