vue中prop验证、类型检查及注意事项

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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值