淺談Vuejs Prop基本用法
這兩天學(xué)習(xí)了Vuejs Prop感覺(jué)這個(gè)地方知識(shí)點(diǎn)挺多的,而且很重要,所以,今天添加一點(diǎn)小筆記。
一、使用Prop傳遞數(shù)據(jù)
組件實(shí)例的作用域是孤立的。這意味著不能并且不應(yīng)該在子組件的模板內(nèi)直接引用父組件的數(shù)據(jù)。可以使用props把數(shù)據(jù)傳給子組件。
prop是父組件用來(lái)傳遞數(shù)據(jù)的一個(gè)自定義屬性。子組件需要顯示的地用props選項(xiàng)聲明”prop”
Vue.component('child',{ props:['message'], template:'<span>{{ message }}</span>' })
然后向它傳入一個(gè)普通字符串:
<child message="hello!"></child>
結(jié)果:
hello!
二、camelCase vs.kebab-case
html不區(qū)分大小寫(xiě)。當(dāng)使用非字符串模板時(shí),prop的名字形式會(huì)從camelCase轉(zhuǎn)為kebab-case(短橫線(xiàn)隔開(kāi)):
//camelCase Vue.component('child',{ props:['myMessage'], template:'<span>{{ message }}</span>' })
//kebab-case <child my-message="hello!"></child>
再次說(shuō)明,如果你是用字符串模板,不用在意這些限制。
三、動(dòng)態(tài)Prop
類(lèi)似于用v-bind綁定HTML特性到一個(gè)表達(dá)式,也可以用v-bind動(dòng)態(tài)綁定props的值到父組件的數(shù)據(jù)中。每當(dāng)父組件的數(shù)據(jù)變化時(shí),該變化也會(huì)傳導(dǎo)給子組件。
<div> <input v-model="parrentMsg"> <br> <child v-bind:my-message="parrentMsg"></child> </div>
使用v-bind的縮寫(xiě)語(yǔ)法通常更簡(jiǎn)單:
<child :my-message="parrentMsg"></child>
四、字面量語(yǔ)法vs動(dòng)態(tài)語(yǔ)法
因?yàn)樗且粋€(gè)字面prop ,它的值以字符串 "1" 而不是以實(shí)際的數(shù)字傳下去。如果想傳遞一個(gè)實(shí)際的 JavaScript 數(shù)字,需要使用 v-bind ,從而讓它的值被當(dāng)作 javascript 表達(dá)式計(jì)算:
五、單項(xiàng)數(shù)據(jù)流
prop是單項(xiàng)綁定的:當(dāng)父組件的屬性變化時(shí),將傳導(dǎo)給子組件,但是不會(huì)反過(guò)來(lái)。這是為了防止子組件無(wú)意修改了父組件的狀態(tài)——這會(huì)讓?xiě)?yīng)用的數(shù)據(jù)流難以理解。同時(shí),這也很好理解,父組件是子組件的高度抽象,表示子組件的共有部分,一個(gè)組件的數(shù)據(jù)改變并不會(huì)改變其抽象,然而其抽象的改變卻代表著所有子組件的改變。
另外,每次組漸漸更新時(shí),子組件的所有prop都會(huì)更新為最新值。這意味著你不應(yīng)該在子組件內(nèi)部改變prop。如果你這么做了,Vue會(huì)在控制臺(tái)給出警告。
通常有兩種改變prop的情況:
1.prop作為初始值傳入,子組件之后只是將它的初始值作為本地?cái)?shù)據(jù)的初始值使用;
2.prop作為需要被轉(zhuǎn)變的原始值傳入。
更確切地說(shuō)這兩種情況是:
a.定義一個(gè)局部data屬性,并將prop的初始值作為局部數(shù)據(jù)的初始值。
“` props: [‘initialCounter'], data: function () { return { counter: this.initialCounter} }
b.定義一個(gè) computed 屬性,此屬性從 prop 的值計(jì)算得出。
``` props: ['size'], computed: { normalizedSize: function () { return this.size.trim().toLowerCase() } }
六、Prop驗(yàn)證
組件可以為 props 指定驗(yàn)證要求。如果未指定驗(yàn)證要求,Vue 會(huì)發(fā)出警告。當(dāng)組件給其他人使用時(shí)這很有用。
prop 是一個(gè)對(duì)象而不是字符串?dāng)?shù)組時(shí),它包含驗(yàn)證要求:
Vue.component('example', { props: { // 基礎(chǔ)類(lèi)型檢測(cè) (`null` 意思是任何類(lèi)型都可以) propA: Number, // 多種類(lèi)型 propB: [String, Number], // 必傳且是字符串 propC: { type: String, required: true }, // 數(shù)字,有默認(rèn)值 propD: { type: Number, default: 100 }, // 數(shù)組/對(duì)象的默認(rèn)值應(yīng)當(dāng)由一個(gè)工廠函數(shù)返回 propE: { type: Object, default: function () { return { message: 'hello' } } }, // 自定義驗(yàn)證函數(shù) propF: { validator: function (value) { return value > 10 } } } })
type可以是下面的原生構(gòu)造器:
- String
- Number
- Boolean
- Function
- Object
- Array
type也可以是一個(gè)自定義構(gòu)造器,使用instanceof檢測(cè)。當(dāng)prop驗(yàn)證失敗了,如果使用的是開(kāi)發(fā)版本會(huì)拋出一條警告。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue Echarts渲染數(shù)據(jù)導(dǎo)致殘留臟數(shù)據(jù)的問(wèn)題處理
這篇文章主要介紹了Vue Echarts渲染數(shù)據(jù)導(dǎo)致殘留臟數(shù)據(jù)的問(wèn)題處理,文中通過(guò)代碼示例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08vue指令只能輸入正數(shù)并且只能輸入一個(gè)小數(shù)點(diǎn)的方法
這篇文章主要介紹了vue指令只能輸入正數(shù)并且只能輸入一個(gè)小數(shù)點(diǎn)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Element Dialog對(duì)話(huà)框的使用示例
這篇文章主要介紹了Element Dialog對(duì)話(huà)框的使用示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07解決vue使用vant下拉框van-dropdown-item 綁定title值不變問(wèn)題
這篇文章主要介紹了解決vue使用vant下拉框van-dropdown-item 綁定title值不變問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08實(shí)現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式
今天小編就為大家分享一篇實(shí)現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11