Vue 組件參數(shù)校驗(yàn)與非props特性的方法
子組件接收父組件的參數(shù)的時(shí)候,props注冊(cè)接收的參數(shù)
props:['count']
子組件可以對(duì)接收的參數(shù)校驗(yàn)。
例如規(guī)定接收的count參數(shù)要求是String
props:{
count:String
}
如果count是別的類型就會(huì)報(bào)錯(cuò)
組件的參數(shù)校驗(yàn)
組件的參數(shù)校驗(yàn)指的是什么呢?你父組件向子組件傳遞的內(nèi)容,子組件有權(quán)對(duì)這個(gè)內(nèi)容進(jìn)行一些約束,這個(gè)約束我們可以把它叫做參數(shù)的校驗(yàn)。
<div id="root">
<child content="hello world"></child>
</div>
Vue.component('child',{
props: ['content'],
template: '<div>{{content}}</div>'
})
let vm = new Vue({
el: '#root',
})
現(xiàn)在有這樣一個(gè)需求,父組件調(diào)用子組件的時(shí)候,傳遞的這個(gè)content,我要做一些約束,要求它我傳遞過來的content必須是一個(gè)字符串,我們?cè)撛趺磳?shí)現(xiàn)呢?
<div id="root">
<child content="hello world"></child>
</div>
Vue.component('child',{
props: {
content: String //子組件接收到的 content 這個(gè)屬性,必須是一個(gè)字符串類型的
},
template: '<div>{{content}}</div>'
})
let vm = new Vue({
el: '#root',
})
組件接收到的content這個(gè)屬性,必須是一個(gè)字符串類型的,如果我需要的參數(shù)類型是字符串或者數(shù)組,又該怎么寫呢?
props: {
content: [ String, Number ]
},
content的類型,可以用數(shù)組來表示。
content其實(shí)還有更復(fù)雜的用法:
props: {
content: {
type: Sring,
required: true, //必傳
default: 'default value', //默認(rèn)顯示,非必傳會(huì)顯示
validator(value){ //檢測 content 的長度,如果長度大于 5,正常顯示,如果長度小于 5 則報(bào)錯(cuò)
return (value.length > 5)
}
}
}
非props特性
說到非props特性,它一定和props特性相對(duì)應(yīng)。
props特性:當(dāng)你的父組件使用子組件的時(shí)候,通過屬性向子組件傳值的時(shí)候,恰好子組件里面聲明了對(duì)父組件傳遞過來的屬性的一個(gè)接收,也就是說父子組件有個(gè)對(duì)應(yīng)關(guān)系,如果你這么寫我們就把叫做props特性
props特性的特點(diǎn)是,如下圖:
- 我們?cè)谧咏M件里有一個(gè)
content的內(nèi)容傳遞,這個(gè)屬性的內(nèi)容傳遞是不會(huì)在dom標(biāo)簽上進(jìn)行顯示的。 - 當(dāng)你父組件傳遞了
content,你子組件接收了這個(gè)content,你在模版里就可以直接通過插值表達(dá)式或者通過this.content,去取得content里面的內(nèi)容了。

非props特性:父組件向子組件傳遞了一個(gè)屬性,但是子組件并沒有props這塊的內(nèi)容,也就是說子組件并沒有聲明我要接收父組件的傳遞過來的內(nèi)容
非props特點(diǎn):
- 非
props特性在子組件里面,沒辦法獲取到你父組件傳遞的內(nèi)容,因?yàn)槟銐焊鶝]聲明你要獲取的內(nèi)容,也就沒法用。 - 如果我們用的是非
props特性,那么這個(gè)特性是會(huì)顯示在dom標(biāo)簽上的

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
VUE的history模式下除了index外其他路由404報(bào)錯(cuò)解決辦法
在本篇文章里小編給大家分享的是關(guān)于VUE的history模式下除了index外其他路由404報(bào)錯(cuò)解決辦法,對(duì)此有需要的朋友們可以學(xué)習(xí)下。2019-08-08
Vue2?Element?description組件列合并詳解
在使用Vue的時(shí)候經(jīng)常會(huì)涉及到表格的列合并,下面這篇文章主要給大家介紹了給大家Vue2?Element?description組件列合并的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
vue3+element?plus實(shí)現(xiàn)側(cè)邊欄過程
這篇文章主要介紹了vue3+element?plus實(shí)現(xiàn)側(cè)邊欄過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
Vue3+El-Plus實(shí)現(xiàn)表格行拖拽功能完整代碼
在vue3+elementPlus網(wǎng)站開發(fā)中,詳細(xì)完成el-table表格的鼠標(biāo)拖拽/拖曳/拖動(dòng)排序,下面這篇文章主要給大家介紹了關(guān)于Vue3+El-Plus實(shí)現(xiàn)表格行拖拽功能的相關(guān)資料,需要的朋友可以參考下2024-05-05
vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法
這篇文章主要介紹了vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

