Vue props 配置项
功能:让组件接收外部传过来的数据
传递数据:<Demo name="xxx"/>
接收数据:
-
只接收:
props:['name']
-
限制类型:
props:{name:String}
-
限制类型+必要性+指定默认值:
props: { name: { type: String, // 限制类型 required: true // 是否必要的 default: '张三' // 默认值 },
实例
src 文件结构
|-- src
|-- App.vue
|-- main.js
|-- components
|-- Student.vue
App.vue
<template>
<div id="app">
<Student name="李四" sex="男" :age="18"/>
<Student name="王五" sex="男" :age="19"/>
</div>
</template>
<script>
import Student from "@/components/Student";
export default {
name: 'App',
components: {
Student
},
data() {
return {}
}
}
</script>
main.js
import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
new Vue({
render: h => h(App),
}).$mount('#app')
Student.vue
<template>
<div class="school">
<h2>{{msg}}</h2>
<h2>姓名:{{name}}</h2>
<h2>性别:{{sex}}</h2>
<h2>年龄:{{age+1}}</h2>
<hr>
</div>
</template>
<script>
export default {
name: 'Student',
data() {
return {
msg: '你好',
}
},
// 简单声明接受
// props: ['name', 'sex', 'age']
// 接受的同时对数据进行:类型限制
// props: {
// name: String,
// sex: String,
// age: Number
// }
// 接受的同时对数据进行:类型 + 默认值 + 必要性的限制
props: {
name: {
type: String,
required: true // 是否必要的
},
sex: {
type: String,
required: true
},
age: {
type: Number,
default: 99 // 默认值
}
}
}
</script>
不建议直接修改props
备注:props 是只读的,Vue底层会监测对props的修改,如果进行修改,就会发出警告。若业务需求确实需要修改,可以复制 props 的内容到 data 中一份,然后修改 data 的数据
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本