深入了解Vue3组件 | 组件的Props

此处分为以下5个部分讲

image.png

属性的类型

在组件配置项props中,可以以字符串数组形式列出的组件的属性

举例🌰:添加一个自定义属性author,并在props中列出来

动画6.gif

也可以在props中,以对象的形式为每个属性指定值类型

举例🌰:将author的类型设置为字符串

动画7.gif

指定属性类型的好处

  • 相当于为组件提供了文档
  • 当输入错误类型时,浏览器的控制台会给予提示

静态属性和动态属性

传递静态属性

如上例,在使用组件时,直接在组件上添加属性author,并可以为属性传递一个静态属性值LBJ

传递动态属性

在使用组件时,可以使用v-bind为属性动态赋值

可以赋值为一个数字、布尔值、数组、对象等

举例🌰:为组件添加一个动态属性like,值为数字

动画8.gif

可以使用不带参数的 v-bind,将一个对象的所有 property 都作为组件的 prop 传入

举例🌰:在自定义组件my-component上使用v-bind,不带参数

动画9.gif

可以看到最终的结果,传入的对象被展开了

单项数据流

父级组件的更新 prop 会向下流动到子组件,反之则不行,Vue会发出警告

举例🌰:在子组件中修改title的数据

动画10.gif

可以看到报错了:Vue warn]: Attempting to mutate prop “title”. Props are readonly.

这其实时好的,防止子组件意外变更父级组件的状态,从而导致应用的数据流向难以理解

当父级组件的prop值发生变更,子组件中所有的 prop 都将会刷新为最新的值

如果真的想在子组件内部改变 prop,官方提供了两种可能的情形,及对应的做法

情形1:这个 prop 传递一个初始值作为子组件的一个本地数据

推荐做法:在子组件的data中声明一个属性,值为prop的值

举例🌰:父级组件传递initialCounter,子组件声明另外一个变量,将initialCounter的值赋值过去

动画11.gif

以后如果要修改,就直接修改counter

情形2:这个 prop 传递一个初始值需要在子组件中进行计算或转换

推荐做法:在子组件中定义一个对应的计算属性

举例🌰:父组件传递size,子组件通过计算属性重新计算出一个值normalizedSize

动画12.gif

特别注意,对于一个数组或对象类型的 prop,在子组件中变更这个对象或数组本身,将会影响到父组件

属性验证

属性验证有利于给使用组件的人提供帮助

属性验证方式

指定验证的方式,只要给组件的配置项props提供一个特定对象,对象的属性名即使组件prop,值为对应的验证

举例🌰:以下多种验证方式

动画13.gif

propA: Number表示propA的值类型是Number

propB: [String, Number]表示propB的值类型是String或Number

propC: {type: String,required: true} 表示类型为String且必填

除此之外以上展示的,还有其他的验证方式:

propD: {type: Number,default: 1}表示类型为Number且有默认值

propE: {type: Object,default() {return {message: ‘hello’ }}}表示默认值为对象,注意:对象或数组默认值必须从一个函数获取

propF: {validator(value) {return [‘success’,’warning’, ‘danger’].includes(value)}}表示自定义验证函数

propG:{type:Function,default(){return ‘xxx’ }}表示类型为函数且带默认值
开发环境中,当 prop 验证失败时,Vue会发出警告

注意:属性验证会在组件实例创建之前进行验证,因此所有的组件实例的property如data、computed 等, 在 default 或 validator 函数中是不可用的

type的类型

可以是下列原生构造函数中的一个:String、Number、Boolean、Array、Object、Date、Function、Symbol

也可以是一个自定义的构造函数

举例🌰:使用自定义构造函数作为类型

动画14.gif

Prop的大小写命名

HTML中的attribute名是大小写不敏感,所以浏览器会把所有大写字符解释为小写

因此,在组件注册时,prop名使用camelCase (驼峰命名法),prop的名需要使用与HTML中等价的写法

举例🌰:使用在注册组件时,prop名是camelCase

动画15.gif

如果在字符串模板使用,则没有这个限制,既可以使用camelCase也可以使用kebab-case

小结

为了方便,我将注册Props相关内容汇总为一图

2组件Props.png

为了方便批量下载,我将相关的高清思维导图及源文件上传至GitHub,可移步下载:https://github.com/jCodeLife/mind-map

You may also like...