vue中prop验证、类型检查及注意事项
1、注意:null和undefined会通过任何类型检测2、数组或对象的默认值需要通过函数返回。详情看这里props:{// 数组或对象的默认值需要通过函数返回authInfo:{type:Object,default(){return{name:'张三',sex...
·
1、注意:
null和undefined会通过任何类型检测
2、数组或对象类型需要提供默认值的话需要通过函数返回。详情看这里
props:{// 数组或对象的默认值需要通过函数返回
authInfo:{
type:Object,
default(){
return{
name:'张三',
sex:0
}
}
},
list:{
type:Array,
default(){
return[
1,2,3
]
}
}
}
3、使用自定义函数验证
props:{
address:{
validator(value){
return ['黑龙江','吉林','辽宁'].indexOf(value) !== -1
}
}
}
4、非prop的特性:若一个属性传向一个组件,但是该组件并没有定义相应 prop。则该属性称为非prop特性。非prop特性会作用到组件的根元素上。
若非prop中含有组件跟元素定义的属性。则非prop中的值会覆盖组件定义的值(这种情况称作 非prop继承)。style和class例外,它们会发生合并。
详情看这里
不希望非prop继承该怎么办?
如果不希望非prop自动作用到组件的根元素上可以在vue的组件选项里添加 inheritAttrs选项(此选项无法影响class和style的绑定)。
inheritAttrs:false
inheritAttrs属性可以和$attrs配合可以是非prop作用到开发者想作用到的元素上。而不作用的根元素上。例:
<template>
<div>
<input type="text" v-bind="$attrs"> <!--将非prop绑定到此元素-->
</div>
</template>
<script>
export default {
name: "sg-test",
inheritAttrs:false,//禁止 非prop继承
}
</script>
更多推荐
已为社区贡献3条内容
所有评论(0)