這篇文章主要為大家展示了“Vue組件中參數(shù)校驗(yàn)與非props特性的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue組件中參數(shù)校驗(yàn)與非props特性的示例分析”這篇文章吧。
成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),榮成企業(yè)網(wǎng)站建設(shè),榮成品牌網(wǎng)站建設(shè),網(wǎng)站定制,榮成網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,榮成網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。子組件接收父組件的參數(shù)的時(shí)候,props注冊接收的參數(shù)
props:['count']
子組件可以對接收的參數(shù)校驗(yàn)。
例如規(guī)定接收的count參數(shù)要求是String
props:{ count:String }
如果count是別的類型就會報(bào)錯(cuò)
組件的參數(shù)校驗(yàn)
組件的參數(shù)校驗(yàn)指的是什么呢?你父組件向子組件傳遞的內(nèi)容,子組件有權(quán)對這個(gè)內(nèi)容進(jìn)行一些約束,這個(gè)約束我們可以把它叫做參數(shù)的校驗(yàn)。
Vue.component('child',{ props: ['content'], template: ' {{content}}' }) let vm = new Vue({ el: '#root', })
現(xiàn)在有這樣一個(gè)需求,父組件調(diào)用子組件的時(shí)候,傳遞的這個(gè)content
,我要做一些約束,要求它我傳遞過來的content
必須是一個(gè)字符串,我們該怎么實(shí)現(xiàn)呢?
Vue.component('child',{ props: { content: String //子組件接收到的 content 這個(gè)屬性,必須是一個(gè)字符串類型的 }, template: ' {{content}}' }) 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)顯示,非必傳會顯示 validator(value){ //檢測 content 的長度,如果長度大于 5,正常顯示,如果長度小于 5 則報(bào)錯(cuò) return (value.length > 5) } } }
非props特性
說到非props
特性,它一定和props
特性相對應(yīng)。
props
特性:當(dāng)你的父組件使用子組件的時(shí)候,通過屬性向子組件傳值的時(shí)候,恰好子組件里面聲明了對父組件傳遞過來的屬性的一個(gè)接收,也就是說父子組件有個(gè)對應(yīng)關(guān)系,如果你這么寫我們就把叫做props
特性
props
特性的特點(diǎn)是,如下圖:
我們在子組件里有一個(gè)content
的內(nèi)容傳遞,這個(gè)屬性的內(nèi)容傳遞是不會在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è)特性是會顯示在dom
標(biāo)簽上的
以上是“Vue組件中參數(shù)校驗(yàn)與非props特性的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!