亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談Vuejs Prop基本用法

 更新時間:2017年08月17日 09:57:44   作者:jessionlin  
本篇文章主要介紹了Vuejs Prop基本用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

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

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

prop是父組件用來傳遞數(shù)據(jù)的一個自定義屬性。子組件需要顯示的地用props選項聲明”prop”

Vue.component('child',{
  props:['message'],
  template:'<span>{{ message }}</span>'
})

然后向它傳入一個普通字符串:

<child message="hello!"></child>

結(jié)果:

hello!

二、camelCase vs.kebab-case

html不區(qū)分大小寫。當(dāng)使用非字符串模板時,prop的名字形式會從camelCase轉(zhuǎn)為kebab-case(短橫線隔開):

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

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

三、動態(tài)Prop

類似于用v-bind綁定HTML特性到一個表達式,也可以用v-bind動態(tài)綁定props的值到父組件的數(shù)據(jù)中。每當(dāng)父組件的數(shù)據(jù)變化時,該變化也會傳導(dǎo)給子組件。

<div>
  <input v-model="parrentMsg">
  <br>
  <child v-bind:my-message="parrentMsg"></child>
</div>

使用v-bind的縮寫語法通常更簡單:

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

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

因為它是一個字面prop ,它的值以字符串 "1" 而不是以實際的數(shù)字傳下去。如果想傳遞一個實際的 JavaScript 數(shù)字,需要使用 v-bind ,從而讓它的值被當(dāng)作 javascript 表達式計算:

五、單項數(shù)據(jù)流

prop是單項綁定的:當(dāng)父組件的屬性變化時,將傳導(dǎo)給子組件,但是不會反過來。這是為了防止子組件無意修改了父組件的狀態(tài)——這會讓應(yīng)用的數(shù)據(jù)流難以理解。同時,這也很好理解,父組件是子組件的高度抽象,表示子組件的共有部分,一個組件的數(shù)據(jù)改變并不會改變其抽象,然而其抽象的改變卻代表著所有子組件的改變。

另外,每次組漸漸更新時,子組件的所有prop都會更新為最新值。這意味著你不應(yīng)該在子組件內(nèi)部改變prop。如果你這么做了,Vue會在控制臺給出警告。

通常有兩種改變prop的情況:

1.prop作為初始值傳入,子組件之后只是將它的初始值作為本地數(shù)據(jù)的初始值使用;

2.prop作為需要被轉(zhuǎn)變的原始值傳入。

更確切地說這兩種情況是:
a.定義一個局部data屬性,并將prop的初始值作為局部數(shù)據(jù)的初始值。

“` 
props: [‘initialCounter'], 
data: function () { 
return { counter: this.initialCounter} 
}

b.定義一個 computed 屬性,此屬性從 prop 的值計算得出。

  ```
  props: ['size'],
  computed: {
    normalizedSize: function () {
     return this.size.trim().toLowerCase()
   }
  }

六、Prop驗證

組件可以為 props 指定驗證要求。如果未指定驗證要求,Vue 會發(fā)出警告。當(dāng)組件給其他人使用時這很有用。
prop 是一個對象而不是字符串?dāng)?shù)組時,它包含驗證要求:

Vue.component('example', {
 props: {
  // 基礎(chǔ)類型檢測 (`null` 意思是任何類型都可以)
  propA: Number,
  // 多種類型
  propB: [String, Number],
  // 必傳且是字符串
  propC: {
   type: String,
   required: true
  },
  // 數(shù)字,有默認值
  propD: {
   type: Number,
   default: 100
  },
  // 數(shù)組/對象的默認值應(yīng)當(dāng)由一個工廠函數(shù)返回
  propE: {
   type: Object,
   default: function () {
    return { message: 'hello' }
   }
  },
  // 自定義驗證函數(shù)
  propF: {
   validator: function (value) {
    return value > 10
   }
  }
 }
})

type可以是下面的原生構(gòu)造器:

  • String
  • Number
  • Boolean
  • Function
  • Object
  • Array

type也可以是一個自定義構(gòu)造器,使用instanceof檢測。當(dāng)prop驗證失敗了,如果使用的是開發(fā)版本會拋出一條警告。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue Echarts渲染數(shù)據(jù)導(dǎo)致殘留臟數(shù)據(jù)的問題處理

    Vue Echarts渲染數(shù)據(jù)導(dǎo)致殘留臟數(shù)據(jù)的問題處理

    這篇文章主要介紹了Vue Echarts渲染數(shù)據(jù)導(dǎo)致殘留臟數(shù)據(jù)的問題處理,文中通過代碼示例給大家講解的非常詳細,對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-08-08
  • Vue常用的幾個指令附完整案例

    Vue常用的幾個指令附完整案例

    越來越多的人在用Vue,剛開始接觸vue的話常接觸的指令就幾個,統(tǒng)一歸納一下。感興趣的朋友跟隨小編一起看看吧
    2018-11-11
  • vue指令只能輸入正數(shù)并且只能輸入一個小數(shù)點的方法

    vue指令只能輸入正數(shù)并且只能輸入一個小數(shù)點的方法

    這篇文章主要介紹了vue指令只能輸入正數(shù)并且只能輸入一個小數(shù)點的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • Element Dialog對話框的使用示例

    Element Dialog對話框的使用示例

    這篇文章主要介紹了Element Dialog對話框的使用示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 詳解vue的diff算法原理

    詳解vue的diff算法原理

    這篇文章主要介紹了詳解vue的diff算法原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 解讀vue項目防范XSS攻擊問題

    解讀vue項目防范XSS攻擊問題

    這篇文章主要介紹了解讀vue項目防范XSS攻擊問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 解決vue使用vant下拉框van-dropdown-item 綁定title值不變問題

    解決vue使用vant下拉框van-dropdown-item 綁定title值不變問題

    這篇文章主要介紹了解決vue使用vant下拉框van-dropdown-item 綁定title值不變問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式

    實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式

    今天小編就為大家分享一篇實現(xiàn)vuex與組件data之間的數(shù)據(jù)同步更新方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue懸浮表單復(fù)合組件開發(fā)詳解

    vue懸浮表單復(fù)合組件開發(fā)詳解

    這篇文章主要為大家詳細介紹了vue懸浮表單復(fù)合組件開發(fā),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue.js中$set與數(shù)組更新方法

    vue.js中$set與數(shù)組更新方法

    下面小編就為大家分享一篇vue.js中$set與數(shù)組更新方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評論