麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

淺談Vuejs Prop基本用法

2019-11-19 15:46:02
字體:
供稿:網(wǎng)友

這兩天學(xué)習(xí)了Vuejs Prop感覺這個(gè)地方知識(shí)點(diǎn)挺多的,而且很重要,所以,今天添加一點(diǎn)小筆記。

一、使用Prop傳遞數(shù)據(jù)

組件實(shí)例的作用域是孤立的。這意味著不能并且不應(yīng)該在子組件的模板內(nèi)直接引用父組件的數(shù)據(jù)。可以使用props把數(shù)據(jù)傳給子組件。

prop是父組件用來傳遞數(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ū)分大小寫。當(dāng)使用非字符串模板時(shí),prop的名字形式會(huì)從camelCase轉(zhuǎn)為kebab-case(短橫線隔開):

//camelCaseVue.component('child',{  props:['myMessage'],  template:'<span>{{ message }}</span>'})
//kebab-case<child my-message="hello!"></child>

再次說明,如果你是用字符串模板,不用在意這些限制。

三、動(dòng)態(tài)Prop

類似于用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的縮寫語法通常更簡(jiǎn)單:

<child :my-message="parrentMsg"></child>

四、字面量語法vs動(dòng)態(tài)語法

因?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ì)反過來。這是為了防止子組件無意修改了父組件的狀態(tài)――這會(huì)讓應(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)變的原始值傳入。

更確切地說這兩種情況是:
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ǔ)類型檢測(cè) (`null` 意思是任何類型都可以)  propA: Number,  // 多種類型  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)證失敗了,如果使用的是開發(fā)版本會(huì)拋出一條警告。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美成人精品欧美一级乱黄 | gogo全球大胆高清人露出91 | 国产91久久精品一区二区 | 蜜桃视频最新网址 | 一区二区三区在线视频观看58 | 麻豆蜜桃在线观看 | 久久久中文 | 中文字幕在线观看www | 国产精品久久久久影院老司 | 欧美a∨亚洲欧美亚洲 | 自拍偷拍亚洲图片 | 免费观看一级黄色片 | 伦理三区 | 香蕉视频h | 亚洲国产午夜精品 | 他也色在线视频 | 久久国产亚洲视频 | 精品国产99久久久久久宅男i | 国产亚洲精品久久777777 | 欧美日韩手机在线观看 | 男人午夜小视频 | 色视频在线观看 | 插插操 | 黄a大片| 99精品视频免费看 | 国产精品成人av片免费看最爱 | 久草在线免费资源站 | 欧美人一级淫片a免费播放 久久久久久久久91 国产99久久久久久免费看 | 国产午夜免费视频 | 国产精品一区二区x88av | 久久久久久亚洲综合影院红桃 | 一级黄色大片在线观看 | a免费视频| 免费观看一区二区三区 | 激情久久精品 | 双性帝王调教跪撅打屁股 | 亚洲成人入口 | 亚洲午夜1000理论片aa | 12av毛片 | 视频一区二区视频 | 电影一级毛片 |