• 【Vue3】Props的使用详解


    💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互相学习和建立一个积极的社区。谢谢你的光临,让我们一起踏上这个知识之旅!
    请添加图片描述

    🍋介绍

    Vue3中,Props是一种用于从父组件向子组件传递数据的重要机制。Props可以让我们以声明式的方式将数据传递到子组件,使得组件之间的通信更加简单和可靠。本文将详细介绍Vue3中Props的用法

    🍋回顾上节

    我们首先在根组件中编写下面的数组

    let personList = [
        {id:'a01',name:'大馒头',age:18},
        {id:'a02',name:'馒头',age:19},
        {id:'a03)d03',name:'小馒头',age:22}
      ]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    但是这并不是响应式的数据,接下来我们引入reactive

      import {reactive} from 'vue'
    
    • 1

    但是这样子的话,我们如果在编写代码的时候打错了,也是不会产生错误的,这时候我们就需要用之前学到了接口那节了,Persons是自定义的

     import {type Persons} from '@/types'
      let personList = reactive<Persons>([
        {id:'asudfysafd01',name:'张三',age:18},
        {id:'asudfysafd02',name:'李四',age:20},
        {id:'asudfysaf)d03',name:'王五',age:22}
      ])
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    🍋props基本使用

    接下来我们介绍本文的重点

    我们首先在根组件定义一个a,同时我们定义一个list

    <person a="馒头" list="personList" />
    
    • 1

    这时候我们别忘了在子组件的模版里写,要不然是不会有显示的

        <h2>{{ a }}h2>
        <h2>{{ list }}h2>
    
    • 1
    • 2

    如果仅仅接受a和list的话

    defineProps(['a','list'])
    
    • 1

    这样子运行后的界面如下图
    在这里插入图片描述
    但是这并不是我们想要的,我们想要的是Personlist的每一列数据,我们稍加修改

    <person a="馒头" :list="personList" />
    
    • 1

    在这里插入图片描述
    但是这样太丑了,我们在子组件中加点东西,下面的修改好的模版

    v-for 是 Vue.js 提供的用来循环渲染列表的指令。通过 v-for,你可以遍历数组或对象,并为每个项或键值对执行相应的 DOM 操作

    <template>
      <div class="person">
        <ul>
          <li v-for="i in list" :key="i.id">
            {{i.name}} - {{i.age}}
          li>
        ul>
    div>
     template>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    下图就是我们想要的展示了
    在这里插入图片描述
    但是只接受的话,根组件如果写错了,有可能发现不出来,并且在页面显示上会产生一定的问题,这就需要我们加一点限制了

      // 接收list + 限制类型
      defineProps<{list:Persons}>()
    
    • 1
    • 2

    一旦出错会有提示
    在这里插入图片描述
    还有一种更高级的,设置了一个默认值,同时使用?用来限制必要性

      //  接收list + 限制类型 + 限制必要性 + 指定默认值
      withDefaults(defineProps<{list?:Persons}>(),{
        list:()=> [{id:'a04',name:'枣馒头',age:23}]
      })
    
    • 1
    • 2
    • 3
    • 4

    注意:defineProps是一个用于定义组件 Props 的函数,它可以在组件的 setup 函数中直接使用,而无需导入

    🍋优势

    优点:

    简洁明了: 使用 defineProps 可以在组件的 setup 函数中直接定义 Props,使得组件逻辑更加清晰和简洁
    
    类型推断: 在使用 defineProps 定义 Props 时,可以根据指定的类型进行类型推断,提高了代码的健壮性和可读性
    
    默认值和属性验证: 可以方便地指定 Props 的默认值和进行属性验证,确保组件的稳健性和可靠性
    
    无需导入: 使用 defineProps 不需要导入任何其他模块,可以直接在组件中使用,减少了代码的复杂性
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    缺点:

    仅适用于 setup 函数: defineProps 只能在组件的 setup 函数中使用,如果组件逻辑较为复杂,可能会导致 setup 函数过于臃肿
    
    无法在模板中直接使用: 使用 defineProps 定义的 Props 不能直接在模板中使用,需要在 setup 函数中将其映射到返回的对象中才能在模板中使用
    
    • 1
    • 2
    • 3

    🍋总结

    通过上述内容,我们可以看到在Vue3中如何使用Props来实现父子组件之间的数据传递,并掌握了Props的基本用法、属性验证、默认值设置等技巧。 Props是Vue3中非常重要的一个特性,熟练掌握Props的使用将有助于我们更好地构建可复用、灵活的组件

    请添加图片描述

    挑战与创造都是很痛苦的,但是很充实。

  • 相关阅读:
    Leetcode—206.反转链表【简单】
    一些好用的系统、组件记录
    网络安全-端口信息收集
    python_data_analysis_and_mining_action-master-5
    linux下使用vscode对C++项目进行编译
    c++中的特殊类设计
    前端提高代码质量-提升代码的可维护性
    操作系统-进程与线程(进程的概念、组成、特征、状态与转化)
    【SQL】SQL语句执行顺序
    短视频直播盈利系统 专为企业打造的短视频直播盈利课(价值1980元)
  • 原文地址:https://blog.csdn.net/null18/article/details/136430613