91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用vuejs prop

發布時間:2021-11-01 15:15:35 來源:億速云 閱讀:125 作者:iii 欄目:編程語言

這篇文章主要講解了“怎么使用vuejs prop”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么使用vuejs prop”吧!

vuejs prop的用法:1、使用Prop傳遞數據,語句如“<child message="hello!"></child>”;2、用v-bind動態綁定props的值到父組件的數據中等等。

怎么使用vuejs prop

本文操作環境:windows7系統、vue2.9.6版,DELL G3電腦。

Vuejs Prop基本用法

一、使用Prop傳遞數據

組件實例的作用域是孤立的。這意味著不能并且不應該在子組件的模板內直接引用父組件的數據。可以使用props把數據傳給子組件。

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

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

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

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

結果:

hello!

二、camelCase vs.kebab-case

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

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

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

三、動態Prop

類似于用v-bind綁定HTML特性到一個表達式,也可以用v-bind動態綁定props的值到父組件的數據中。每當父組件的數據變化時,該變化也會傳導給子組件。

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

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

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

四、字面量語法vs動態語法

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

五、單項數據流

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

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

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

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

2.prop作為需要被轉變的原始值傳入。

更確切地說這兩種情況是:

a.定義一個局部data屬性,并將prop的初始值作為局部數據的初始值。
“`
props: [‘initialCounter’],
data: function () {
return { counter: this.initialCounter}
}
    b.定義一個 computed 屬性,此屬性從 prop 的值計算得出。
   ```
    props: ['size'],
    computed: {
        normalizedSize: function () {
         return this.size.trim().toLowerCase()
     }
    }

六、Prop驗證

組件可以為 props 指定驗證要求。如果未指定驗證要求,Vue 會發出警告。當組件給其他人使用時這很有用。

prop 是一個對象而不是字符串數組時,它包含驗證要求:

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

type可以是下面的原生構造器:

* String

* Number

* Boolean

* Function

* Object

* Array

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

感謝各位的閱讀,以上就是“怎么使用vuejs prop”的內容了,經過本文的學習后,相信大家對怎么使用vuejs prop這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥中县| 太谷县| 巫溪县| 镶黄旗| 河池市| 宾阳县| 江油市| 墨竹工卡县| 巩义市| 万年县| 桓台县| 宕昌县| 东乌珠穆沁旗| 宁国市| 宝兴县| 揭西县| 仁寿县| 汉沽区| 临汾市| 保德县| 翁牛特旗| 绥棱县| 甘南县| 平原县| 常熟市| 马鞍山市| 朝阳市| 万全县| 甘洛县| 南昌市| 太仓市| 平安县| 资兴市| 集贤县| 南投市| 桐柏县| 昌江| 建湖县| 呼图壁县| 隆回县| 民丰县|