vue2知识点:组件的props属性、非props属性、props属性校验

简介: vue2知识点:组件的props属性、非props属性、props属性校验

image.png

@[toc]

3.10props属性

组件可以嵌套使用,叫做父子组件。那么父组件经常要给子组件传递数据这叫做父子组件通信。父子组件的关系可以总结为 props 向下传递,事件向上传递。父组件通过 prop 给子组件下发数据,子组件通过事件给父组件发送消息。看看它们是怎么工作的:

image.png

使用父组件给子组件传递属性流程:
1. 在父组件中定义数据
2. 在使用组件时,绑定父组件中的数据
3. 在子组件中通过props属性声明父组件中传递过来的参数
4. 在template属性中使用父组件中的参数
## 举例:父组件给子组件传递属性msg和greetText,子组件用属性a和b接收,并打印输出

java <div id="app"> <!-- v-bind:a 简写成 :a --> <child :a="msg" :b="greetText"></child> </div> <script> /*** * 父子组件通信: 父组件通过props属性向子组件进行数据传递 * 使用方式: 子组件定义时用props指定接收参数名 * */ Vue.component('child', { //声明props props:['a','b'], //使用父组件传递的数据 template:'<span>{ {a}} == { {b}}</span>' }); var app = new Vue({ el:'#app', data:{ msg:'来自父组件的消息', greetText:'你好Child' } }); </script>

> 结果展示

image.png

# 3.11props校验
image.png

子组件在接收父组件传入数据时, 可以进行prop校验,来确保数据的格式和是否必传。

注意点1:props可配置3种形式,如果没有参数格式化校验,推荐形式1使用居多。

> 形式1:简单声明接收

java props:['name','age','sex']

> 形式2:接收的同时对数据进行类型限制

java props:{ name:String, age:Number, sex:String }

> 形式3:接收的同时对数据:进行类型限制+默认值的指定+必要性的限制

java props:{ name:{ type:String, //name的类型是字符串 required:true, //name是必要的 }, age:{ type:Number, default:99 //默认值 }, sex:{ type:String, required:true } }
注意点2:

问题:如果data中属性名和props中属性重名,谁优先级高?

答案:props种属性名优先级高,因此为了避免不必要问题,避免data中属性名和props中属性重名

注意点3:props后面是对象而不是数组形式(即:只接收属性不校验可使用数组形式,如props:[],如果要进行校验请使用对象形式,如props:{}),同时可以指定以下属性:
1) type: 指定数据类型 String Number Object ...注意不能使用字符串数组,只能是对象大写形式
2) required: 指定是否必输
3) default: 给默认值或者自定义函数返回默认值
4) validator: 自定义函数校验

形式如下:

Vue.component('example', {
   
  props: {
   
    // 基础类型检测 (`null` 指允许任何类型)
    propA: Number,
    // 可能是多种类型
    propB: [String, Number],
    // 必传且是字符串
    propC: {
   
      type: String,
      required: true
    },
    // 数值且有默认值
    propD: {
   
      type: Number,
      default: 100
    },
    // 数组/对象的默认值应当由一个工厂函数返回
    propE: {
   
      type: Object,
      default: function () {
   
        return {
    message: 'hello' }
      }
    },
    // 自定义验证函数
    propF: {
   
      validator: function (value) {
   
        return value > 10
      }
    }
  }
})

举例

完整代码:

<div id="app">
    <child :a="msg" :c="greetText" :f="hello"></child>
</div>
<script>
    Vue.component('child', {
   
        //声明props 检验
        props:{
   
            'a': String,
            'b': [Number,String],
            'c': {
   
                required:true
            },
            'd':{
   
                default:100
            },
            e:{
   
                type: Number,
                default: function () {
   
                    return 1;
                }
            },
            f:{
   
                type:Number,
                validator: function (value) {
   
                    return value < 100;
                }
            }
        },
        template:'<span>{
   {a}} == {
   {d}} == {
   {e}} == {
   {f}}</span>'
    });
    var app = new Vue({
   
        el:'#app',
        data:{
   
            msg:'来自父组件的消息',
            greetText:'你好Child',
            hello:12
        }
    });
</script>

结果展示

image.png

注意点4:props是用来接收传递过来的属性值,最后会统一绑定到vc上,最好不要直接修改props的属性值(也就是不要直接修改vc上面的props接收的属性值,会报错),会报错如图,所以为了避免这个问题,最好的解决方案是在data中重新定一个新属性值,用来接收props中传递过来的参数属性
image.png

注意点5:组件标签传递的属性名也是有限制的,不能啥都瞎传,比如你想传递key就会报错如图,报错说key已经被征用了,不让使用

<Student name="李四" sex="女" :age="18" key=123/>
props:['name','age','sex',key]

image.png

3.12非props属性

标签引用子组件时,非定义的props属性,自动合并到子组件上,class和style也会自动合并,如果class或者style重复采用就近原则。

举例:定义子组件设置class和style,而标签引用子组件时也设置了class和style,那么会进行属性合并,如果重名采用就近原则。

<div id="app">
    <child data-index="0" class="cont" style="font-size: 20px;"></child>
</div>
<script>
    /***
     * 引用子组件: 非定义的prop属性,自动合并到子组件上,class和style也会自动合并
     * */
    Vue.component('child', {
   
        template:'<span class="item" style="color:red;">我是child</span>'
    });
    var app = new Vue({
   
        el:'#app'
    });
</script>

结果展示

image.png

本人其他相关文章链接

1.《基础篇第1章:vue2简介》包含Vue2知识点、个人总结的使用注意点及碰到的问题总结

2.《基础篇第2章:vue2基础》包含Vue2知识点、个人总结的使用注意点及碰到的问题总结

3.《进阶篇第3章:vue进阶-组件》包含组件、自定义事件、插槽、路由等等扩展知识点

4.《基础篇第4章》:使用vue脚手架创建项目

5.vue2知识点:数据代理

6.vue2知识点:事件处理

7.vue2知识点:列表渲染(包含:v-for、key、取值范围、列表过滤、列表排序、vue监视对象或数组的数据改变原理、总结vue数据监测)

8.vue2知识点:计算属性与监听属性

9.vue2知识点:生命周期(包含:生命周期介绍、生命周期钩子、整体流程图详解)

10.vue2知识点:非单文件组件和单文件组件

11.vue2知识点:组件is属性

12.vue2知识点:组件模板定义

13.vue2知识点:组件的props属性、非props属性、props属性校验

14.vue2知识点:组件自定义事件

15.vue2知识点:组件插槽分发

16.vue2知识点:动态组件

17.vue2知识点:混入

18.vue2知识点:浏览器本地缓存

19.vue2知识点:全局事件总线(GlobalEventBus)

20.vue2知识点:消息订阅与发布

21.vue2知识点:nextTick语法

22.vue2知识点:Vue封装的过度与动画

23.vue2知识点:路由

24.vue2知识点:vm调用待$命令介绍

25.vue组件通信案例练习(包含:父子组件通信及平行组件通信)

26.vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解

27.vue2基础组件通信案例练习:待办事项Todo-list案例练习

28.vue2基础组件通信案例练习:把案例Todo-list改写成本地缓存

29.vue2基础组件通信案例练习:把案例Todo-list改成使用自定义事件

30.vue2基础组件通信案例练习:把案例Todo-list改成使用全局事件总线

31.vue2基础组件通信案例练习:把案例Todo-list改成使用消息订阅与发布

32.vue2基础组件通信案例练习:把案例Todo-list新增编辑按钮

33.vue2基础组件通信案例练习:把案例Todo-list改成使用动画与过度

34.学习vue2遇到过的问题及个人总结

目录
相关文章
element-plus:el-date-picker日期只选择年月不要日
element-plus:el-date-picker日期只选择年月不要日
1364 0
el-tree技巧之只能选中最后一层级的子节点以及查找树结构第一个无子节点的叶节点
el-tree技巧之只能选中最后一层级的子节点以及查找树结构第一个无子节点的叶节点
|
JavaScript
Vue2.0、Vue3.0分别使用v-model封装组件[Vue必会]
本文介绍了在Vue 2和Vue 3中如何使用`v-model`来实现组件间的双向数据绑定,包括在Vue 2中使用`value`和`input`事件,以及在Vue 3中使用`modelValue`和`update:modelValue`事件的方法。
821 22
Element UI 日期选择器el-date-picker禁止选择指定日期(禁止选择过去,禁止选择未来)【含是否包含今天】
Element UI 日期选择器el-date-picker禁止选择指定日期(禁止选择过去,禁止选择未来)【含是否包含今天】
794 3
|
12月前
|
前端开发 JavaScript Docker
拿下奇怪的前端报错(五):SyntaxError: Unexpected token ‘??=‘或‘xxx‘ - 基于容器搭建开发环境或许是更好的选择
在前端开发中,同时维护多个项目时可能会遇到不同Node.js版本的问题。低版本Node.js可能导致依赖无法安装或启动失败,而高版本Node.js则可能引起第三方库的兼容性问题。推荐使用Docker搭建独立的开发环境,以避免版本不一致带来的困扰。
2842 2
|
JavaScript 前端开发 安全
【Vue3 + Vite】6个非常强大的后台管理项目!开源且免费!
【Vue3 + Vite】6个非常强大的后台管理项目!开源且免费!
|
12月前
|
缓存 前端开发 UED
前端 8 种图片加载优化方案梳理
本文首发于微信公众号“前端徐徐”,详细探讨了现代网页设计中图片加载速度优化的重要性及方法。内容涵盖图片格式选择(如JPEG、PNG、WebP等)、图片压缩技术、响应式图片、延迟加载、CDN使用、缓存控制、图像裁剪与缩放、Base64编码等前端图片优化策略,旨在帮助开发者提升网页性能和用户体验。
2285 0
|
JavaScript
基于Vue2或Vue3实现任意上下左右拖拽悬浮的元素,且配置为自定义的全局指令
这篇文章介绍了如何在Vue 2或Vue 3项目中实现一个自定义的全局指令`v-dragSwitch`,用于创建可以任意方向拖拽并悬浮的元素,同时包含边界处理的逻辑。
3550 2
基于Vue2或Vue3实现任意上下左右拖拽悬浮的元素,且配置为自定义的全局指令