Vue 組件參數(shù)校驗與非props特性的方法
子組件接收父組件的參數(shù)的時候,props注冊接收的參數(shù)
props:['count']
子組件可以對接收的參數(shù)校驗。
例如規(guī)定接收的count參數(shù)要求是String
props:{ count:String }
如果count是別的類型就會報錯
組件的參數(shù)校驗
組件的參數(shù)校驗指的是什么呢?你父組件向子組件傳遞的內(nèi)容,子組件有權(quán)對這個內(nèi)容進行一些約束,這個約束我們可以把它叫做參數(shù)的校驗。
<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)在有這樣一個需求,父組件調(diào)用子組件的時候,傳遞的這個content
,我要做一些約束,要求它我傳遞過來的content
必須是一個字符串,我們該怎么實現(xiàn)呢?
<div id="root"> <child content="hello world"></child> </div> Vue.component('child',{ props: { content: String //子組件接收到的 content 這個屬性,必須是一個字符串類型的 }, template: '<div>{{content}}</div>' }) let vm = new Vue({ el: '#root', })
組件接收到的content
這個屬性,必須是一個字符串類型的,如果我需要的參數(shù)類型是字符串或者數(shù)組,又該怎么寫呢?
props: { content: [ String, Number ] },
content
的類型,可以用數(shù)組來表示。
content
其實還有更復(fù)雜的用法:
props: { content: { type: Sring, required: true, //必傳 default: 'default value', //默認顯示,非必傳會顯示 validator(value){ //檢測 content 的長度,如果長度大于 5,正常顯示,如果長度小于 5 則報錯 return (value.length > 5) } } }
非props特性
說到非props
特性,它一定和props
特性相對應(yīng)。
props
特性:當你的父組件使用子組件的時候,通過屬性向子組件傳值的時候,恰好子組件里面聲明了對父組件傳遞過來的屬性的一個接收,也就是說父子組件有個對應(yīng)關(guān)系,如果你這么寫我們就把叫做props
特性
props
特性的特點是,如下圖:
- 我們在子組件里有一個
content
的內(nèi)容傳遞,這個屬性的內(nèi)容傳遞是不會在dom
標簽上進行顯示的。 - 當你父組件傳遞了
content
,你子組件接收了這個content
,你在模版里就可以直接通過插值表達式或者通過this.content
,去取得content
里面的內(nèi)容了。
非props
特性:父組件向子組件傳遞了一個屬性,但是子組件并沒有props
這塊的內(nèi)容,也就是說子組件并沒有聲明我要接收父組件的傳遞過來的內(nèi)容
非props
特點:
- 非
props
特性在子組件里面,沒辦法獲取到你父組件傳遞的內(nèi)容,因為你壓根沒聲明你要獲取的內(nèi)容,也就沒法用。 - 如果我們用的是非
props
特性,那么這個特性是會顯示在dom
標簽上的
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue基于vuex、axios攔截器實現(xiàn)loading效果及axios的安裝配置
這篇文章主要介紹了Vue基于vuex、axios攔截器實現(xiàn)loading效果及axios的安裝配置,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04vue-cli2與vue-cli3在一臺電腦共存的實現(xiàn)方法
這篇文章主要介紹了vue-cli2與vue-cli3在一臺電腦共存的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Vue中實現(xiàn)v-for循環(huán)遍歷圖片的方法
這篇文章主要介紹了Vue中實現(xiàn)v-for循環(huán)遍歷圖片的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08