VueJs組件prop驗證簡單介紹
組件
Vue.js引入的組件,讓分解單一HTML到獨立組件成為可能。組件可以自定義元素形式使用,或者使用原生元素但是以is特性做擴展。
今天看了vuejs的組件,看到了prop組件,主要作用是在傳入數(shù)據(jù)的時候?qū)魅氲闹底雠袛?,寫了個小例子。
<div id="app">
<my-child
:num="100"
:msg="'sdf'"
:object="{a:'a'}"
:cust="100"
></child>
</div>
<script type="text/javascript">
Vue.component('my-child', {
props: {
// 基礎(chǔ)類型檢測 (`null` 意思是任何類型都可以)
num: Number,
// 多種類型
propB: [String, Number],
// 必傳且是字符串
msg: {
type: String,
required: true
},
// 數(shù)字,有默認(rèn)值
num1: {
type: Number,
default: 1000
},
// 數(shù)組/對象的默認(rèn)值應(yīng)當(dāng)由一個工廠函數(shù)返回
object: {
type: Object,
default: function () {
return { message: 'hello' }
}
},
// 自定義驗證函數(shù)
cust: {
validator: function (value) {
return value > 10
}
}
},
template: `<div>
<p>{{ num }}</p>
<p>{{ msg }}</p>
<p>{{ num1 }}</p>
<p>{{ object }}</p>
<p>{{ cust }}</p>
</div>`
})
new Vue({
el: "#app"
});
</script>
輸出結(jié)果
這里都是通過驗證了的,能夠全部輸出來,而且控制臺沒有報錯。
如果有不符合的,控制臺會報錯。
<div id="app">
<my-child
:num="asd"
:msg="sdf"
:object="{a:'a'}"
:cust="100"
></child>
</div>
對應(yīng)的,也沒有渲染出來
但是也有一些是報錯了但是渲染出來的。比如
<div id="app">
<my-child
:num="100"
:msg="'sdf'"
:object="{a:'a'}"
:cust="1"
></child>
</div>
所以,這個驗證功能多的還是用作于開發(fā),或者說寫的組件讓別的開發(fā)者使用是做的認(rèn)證。(完全初學(xué)不太懂,如果有什么寫錯或者說這個驗證還有什么功能,請在評論寫下,先謝謝你了)
總結(jié)
以上所述是小編給大家介紹的VueJs組件prop驗證簡單理解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
electron-vue中報錯Cannot?use?import?statement?outside?a?m
Electron 是一個使用 JavaScript、HTML 和 CSS 構(gòu)建桌面應(yīng)用程序的框架,下面這篇文章主要給大家介紹了關(guān)于electron-vue中報錯Cannot?use?import?statement?outside?a?module的解決方案,需要的朋友可以參考下2023-02-02
Vue3中使用ref與reactive創(chuàng)建響應(yīng)式數(shù)據(jù)的示例代碼
這篇文章主要介紹了Vue3中使用ref與reactive創(chuàng)建響應(yīng)式數(shù)據(jù)的方法,文中通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08
淺析webpack-bundle-analyzer在vue-cli3中的使用
這篇文章主要介紹了webpack-bundle-analyzer在vue-cli3中的使用,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10

