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

Vue組件數(shù)據(jù)傳遞與props校驗方式

 更新時間:2024年08月15日 15:18:27   作者:專注寫bug  
這篇文章主要介紹了Vue組件數(shù)據(jù)傳遞與props校驗方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

前言

組件與組件之間并不是完全獨立的,他們之間可以進行一些數(shù)據(jù)的傳遞操作。

傳遞數(shù)據(jù)的解決方案就是props選項。

組件數(shù)據(jù)傳遞的幾種類型

簡單字符串類型數(shù)據(jù)專遞

比如定義兩個頁面Parent.vueChild.vue,其中Parent.vue包含Child.vue。

  • Child.vue
<template>
 <div class="div">
   <h1>子類組件</h1><br>
   <p>msg: {{ msg }}</p><br>
   <p>title: {{ title }}</p><br>
 </div>
 
</template>
<script>
export default{
 data(){
  return{
   
  }
 },
 // props 數(shù)組類型,其中保存父級傳入子級數(shù)據(jù)時,標(biāo)簽上的屬性名稱
 props:["msg","title"]
}
</script>
<style scoped>
.div{
 border: 1px solid;
}</style>
  • >Parent.vue
<template>
 <h1>父類組件</h1><br>
 <ChildDemo msg="專注寫bug 父級傳入子級數(shù)據(jù)" :title="tittleMsg"/>
</template>
<script>
// 父類中引入子類
import Child from './Child.vue';
export default{
 data(){
  return{
    tittleMsg:"父級傳入子級信息2"
  }
 },
 // script 增加 setup,則不能寫邏輯,出現(xiàn)報錯,所以此處手動注入
 components:{
  // key-value 結(jié)構(gòu)   別名:對應(yīng)引入子類
  ChildDemo:Child
 }
}
</script>

案例效果展示:

其他類型數(shù)據(jù)(數(shù)字、數(shù)組、對象)傳遞

  • 如果按照J(rèn)ava語言理解,就很簡單。
  • 萬物皆對象。既然字符串是這種方式,那么其他類型也大差不差了!

直接看例子:

  • Parent.vue
<template>
 <h1>父類組件</h1><br>
 <ChildDemo msg="專注寫bug 父級傳入子級數(shù)據(jù)" 
  :title="tittleMsg" 
  :age="userAge" 
  :arrays="userLists" 
  :userInfo="userInfos" />
</template>
<script>
// 父類中引入子類
import Child from './Child.vue';
export default{
 data(){
  return{
    tittleMsg:"父級傳入子級信息2", // 字符串
    userAge:28, // number 數(shù)字類型
    userLists:["lilei","jack","tom"], // 數(shù)組類型
    userInfos:{  // object 對象類型
     id:5173,
     name:"lilei"
    }
  }
 },
 // script 增加 setup,則不能寫邏輯,出現(xiàn)報錯,所以此處手動注入
 components:{
  // key-value 結(jié)構(gòu)   別名:對應(yīng)引入子類
  ChildDemo:Child
 }
}
</script>
  • Child.vue
<template>
 <div class="div">
   <h1>子類組件</h1><br>
   <p>msg: {{ msg }}</p><br>
   <p>title: {{ title }}</p><br>
   <p>age: {{ age }}</p><br>
   <ul>
    <li v-for="(item,index) of arrays" :key="index">{{ item }}</li>
   </ul>

   <p>用戶基本信息編號:{{ userInfo.id  }} </p>
   <p>用戶基本信息名稱: {{ userInfo.name }}</p>
 </div>
 
</template>
<script>
export default{
 data(){
  return{
   
  }
 },
 props:["msg","title","age","arrays","userInfo"]
}
</script>
<style scoped>
.div{
 border: 1px solid;
}</style>

注意事項

  • props傳遞數(shù)據(jù)操作時,只能從父級傳遞至子級中,即:從外至內(nèi)
  • 不能反其道而行!

數(shù)據(jù)傳遞值校驗

  • 在上面的案例中,父級組件Parent.vue向子級組件Child.vue進行了傳遞數(shù)據(jù)測試。
  • 除了能滿足數(shù)據(jù)傳遞之外,props還能針對傳遞的數(shù)據(jù)限定類型、若不存在填充默認(rèn)值等操作。

限定數(shù)據(jù)類型 type

比如父級中傳遞的userAgeString類型,若子級組件中定義的是Number類型。

則會出現(xiàn)什么樣的問題呢?看下面的案例。

  • ComponentA.vue
<template>
 <h1>父類組件</h1><br>
 <ComponentBDemo 
  :age="userAge"  />
</template>
<script>
// 父類中引入子類
import ComponentB from './ComponentB.vue';
export default{
 data(){
  return{
    userAge:"28", // 傳遞字符串類型
  }
 },
 // script 增加 setup,則不能寫邏輯,出現(xiàn)報錯,所以此處手動注入
 components:{
  // key-value 結(jié)構(gòu)   別名:對應(yīng)引入子類
  ComponentBDemo:ComponentB
 }
}
</script>

在子級組件中的props換一個寫法,指定數(shù)據(jù)的類型。

  • ComponentB.vue
<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{ // 限定類型
   type:Number
  }
 }
}
</script>

運行后,瀏覽器查看顯示效果。

【發(fā)現(xiàn)】限定類型后,父級組件傳遞的是String類型,但子級組件限定的是Number類型,類型不一致出現(xiàn)了警告!

當(dāng)然,在子級組件中,可以針對多個可能的類型進行限制,比如滿足傳入的數(shù)據(jù)是StringNumber等。

  • 修改子級組件ComponentB.vue
<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array] // 支持多種類型范圍
  }
 }
}
</script>

刷新瀏覽器,查看信息。

給定默認(rèn)值 default

如果子級組件中定義了某個變量的顯示項,但在父級中未傳入對應(yīng)的值,此時子級組件在渲染顯示的時候,不會將該變量標(biāo)簽進行顯示。

  • ComponentB.vue
<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
 <p>{{ userName }}</p><br>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array]
  },
  userName:{
   type:String
  }
 }
}
</script>

子級組件定義userName變量的顯示,但父級未傳遞值,此時瀏覽器中的顯示信息如下:

如果說父級組件未傳遞值時,需要子級組件中默認(rèn)顯示一些信息,可以寫成下面這種形式。

<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
 <p>{{ userName }}</p><br>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array]
  },
  userName:{
   type:String,
   default:"父級未傳遞值,默認(rèn)顯示這句話!"
  }
 }
}
</script>

核心就是針對未傳遞值的變量增加default標(biāo)識 。

export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array]
  },
  userName:{
   type:String,
   default:"父級未傳遞值,默認(rèn)顯示這句話!"
  }
 }
}

此時頁面的顯示效果如下所示:

如果父級傳遞了數(shù)據(jù)。那么顯示效果又是怎么樣的呢?

  • >ComponentA.vue

此時瀏覽器中的顯示效果如下所示:

【注意】數(shù)字Number和字符串String類型,可以直接指定default默認(rèn)值。如果是對象或者數(shù)組類型,則需要使用工廠函數(shù)返回默認(rèn)值!

驗證數(shù)組類型的數(shù)據(jù)默認(rèn)值定義。

<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
 <p>{{ userName }}</p><br>
 <ul>
    <li v-for="(item,index) of arrays" :key="index">{{ item }}</li>
   </ul>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array]
  },
  userName:{
   type:String,
   default:"父級未傳遞值,默認(rèn)顯示這句話!"
  },
  arrays:{ // 數(shù)組類型的變量
   type:Array,
   default(){ // 工廠函數(shù)返回默認(rèn)對象
    return ["這只是默認(rèn)的數(shù)組展示項"]
   }
  }
 }
}
</script>

數(shù)組類型默認(rèn)值展示效果:

指定必選項 required

在上面說了一個顯示效果:

  • 如果父級未傳遞指定變量數(shù)據(jù),則在子級組件中會渲染對應(yīng)的標(biāo)簽,但不會給變量賦值!
  • 如果必須強制指定必須傳遞對應(yīng)的值,此時則需要使用到required:true標(biāo)識。

如下所示:

  • 父級未傳遞值msg,子級組件對應(yīng)變量指定必傳!
<template>
 <h1>子級組件</h1><br>
 <p>age: {{ age }}</p><br>
 <p>{{ userName }}</p><br>
 <ul>
    <li v-for="(item,index) of arrays" :key="index">{{ item }}</li>
   </ul>
</template>
<script>
export default{
 data(){
  return{
    
  }
 },
 props:{
  age:{
   //type:Number // 限定單個類型
   type:[Number,String,Object,Array]
  },
  userName:{
   type:String,
   default:"父級未傳遞值,默認(rèn)顯示這句話!"
  },
  arrays:{
   type:Array,
   default(){
    return ["這只是默認(rèn)的數(shù)組展示項"]
   }
  },
  msg:{ // 父級未傳遞該變量
   type:String,
   required:true
  }
 }
}
</script>

此時瀏覽器中的顯示效果如下:

丟失必選項msg值。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue實現(xiàn)可視化可拖放的自定義表單的示例代碼

    vue實現(xiàn)可視化可拖放的自定義表單的示例代碼

    這篇文章主要介紹了vue實現(xiàn)可視化可拖放的自定義表單的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • vue3+elementUI實現(xiàn)懸浮多行文本輸入框效果

    vue3+elementUI實現(xiàn)懸浮多行文本輸入框效果

    這篇文章主要為大家詳細(xì)介紹了vue3如何引用elementUI實現(xiàn)懸浮文本輸入框效果,以便實現(xiàn)多行文本輸入,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-10-10
  • 詳解在Vue中通過自定義指令獲取dom元素

    詳解在Vue中通過自定義指令獲取dom元素

    本篇文章主要介紹了詳解在Vue中通過自定義指令獲取dom元素 ,具有一定的參考價值,有興趣的可以了解一下。
    2017-03-03
  • 初識 Vue.js 中的 *.Vue文件

    初識 Vue.js 中的 *.Vue文件

    vue.js是一套構(gòu)建用戶界面的漸進式框架,它采用自底向上增量開發(fā)的設(shè)計.這篇文章主要介紹了VueJs 填坑日記之初識 *.Vue文件,需要的朋友可以參考下
    2017-11-11
  • 詳解如何使用Vue2做服務(wù)端渲染

    詳解如何使用Vue2做服務(wù)端渲染

    本篇文章主要介紹了如何使用Vue2做服務(wù)端渲染 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • Vue中computed與methods的區(qū)別詳解

    Vue中computed與methods的區(qū)別詳解

    這篇文章主要介紹了Vue中computed與methods的區(qū)別詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • vue異步組件與組件懶加載問題(import不能導(dǎo)入變量字符串路徑)

    vue異步組件與組件懶加載問題(import不能導(dǎo)入變量字符串路徑)

    這篇文章主要介紹了vue異步組件與組件懶加載問題(import不能導(dǎo)入變量字符串路徑),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue動態(tài)樣式綁定實例詳解

    Vue動態(tài)樣式綁定實例詳解

    眾所周知vue是操作dom元素的,那么如果有元素要動態(tài)綁定樣式,這種需求,還是要通過改變數(shù)據(jù)來改變視圖的樣式,下面這篇文章主要給大家介紹了關(guān)于Vue動態(tài)樣式綁定的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • vue關(guān)于自定義指令與v-if沖突的問題

    vue關(guān)于自定義指令與v-if沖突的問題

    這篇文章主要介紹了vue關(guān)于自定義指令與v-if沖突的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue nextTick的原理解析

    Vue nextTick的原理解析

    這篇文章主要介紹了Vue nextTick的原理解析,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-04-04

最新評論