Vue3---基础7(Props)

props,用于给子组件传递父组件的值的方法

代码示例:

父组件

javascript 复制代码
<template>
    <Text1 :list="personList"/>
</template>

<script lang="ts" setup namae="App">
    import Text1 from './components/text2.vue'
    import { reactive } from 'vue'
    import { type Persons }  from '@/types'

    let personList = reactive<Persons>([
        {id: '19821220', name:'张杰', age: 22},
        {id: '19822024', name:'Jason', age: 25},
    ])

</script>

我在父组件内,定义了数据 personList 数组,并在子组件上绑定了该数据

子组件

javascript 复制代码
<template>
    <div class="person">
        <h2>{{ list }}</h2>
        <ul>
            <li v-for="item in list" :key="item.id">姓名: {{ item.name }}; 年龄:{{ item.age }}</li>
        </ul>
    </div>
</template>

<script lang="ts" setup name="text2">
    import {defineProps, withDefaults} from 'vue'
    import { type Person } from '@/type'

    // 只接收list
    // defineProps(['list'])

    // 接收list + 限制类型
    // defineProps<{list:Person}>()

    // 接收list + 限制类型 + 限制必要性 + 制定默认值
    withDefaults(defineProps<{list:Person}>(), {
        list:()=> [{id: 111222, name: '默认姓名', age: 18}]
    })

    // 接收list  同时将 props 保存起来
    // let x = defineProps(['a', 'list'])
    // console.log('x', x)
    
</script>

有四种方法去使用

第一种

只接收值

第二种

接收值,同时保持该值

第三种

接收值的时候使用<>,限制类型

第四种

接收值的时候,限制类型,限制必要性和设置默认值

defineProps

是用来在子组件内去接收父组件的值

withDefaults

在接收父组件的值时,给该值设置默认值

需要用回调函数去返回该默认值,不能直接设置

xxx:()=> {默认值}

相关推荐
m0_748255268 分钟前
easyExcel导出大数据量EXCEL文件,前端实现进度条或者遮罩层
前端·excel
长风清留扬28 分钟前
小程序毕业设计-音乐播放器+源码(可播放)下载即用
javascript·小程序·毕业设计·课程设计·毕设·音乐播放器
web1478621072341 分钟前
C# .Net Web 路由相关配置
前端·c#·.net
m0_7482478042 分钟前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖1 小时前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案11 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_748254881 小时前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营1 小时前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood2 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架