圆月山庄资源网 Design By www.vgjia.com
prop 传值检验规则
如果是 prop 是静态传值,则必须是 String 类型
如果是 prop 是动态传值,则可以验证任意类型
示例,如果必须要传一个Number,就必须使用 bind
//声明 Vue.component("blog-post", { props: { postTitle: { type: Number, default: 10000 } }, template: "<h3>{{ postTitle }}</h3>" }); //在template中调用,静态传值,值必定是 String <blog-post postTitle="54"></blog-post> //在template中调用,动态传值,值可以是 String、Number、Boolen。。。 <blog-post :postTitle="54"></blog-post>
类型检查的 type 值,可以是下列原生构造函数中的一个:
String
Number
Boolean
Array
Object
Date
Function
Symbol
type 还可以是一个自定义的构造函数,并且通过 instanceof 来进行检查确认。
示例:
//例如,给定下列现成的构造函数: function Person (firstName, lastName) { this.firstName = firstName this.lastName = lastName } //可以使用,检验是否为 Person 的实例 Vue.component('blog-post', { props: { author: Person } })
补充知识: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>
以上这篇vue prop传值类型检验方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
标签:
vue,prop传值,类型检验
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
更新日志
2024年12月23日
2024年12月23日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]