当前位置:   article > 正文

Vue3 - props_vue3 props

vue3 props

props

  • 用于接收父组件传递的值

  • 在使用 <script setup> 的单文件组件中,props 可以使用 defineProps() 宏来声明:

  1. <script setup>
  2. const props=defineProps(['foo'])
  3. console.log(props.foo)
  4. </script>
  • 在没有使用 <script setup> 的组件中,prop 可以使用 props 选项来声明(和vue2一致):

  1. export default {
  2. props: ['foo'],
  3. setup(props) {
  4. // setup() 接收 props 作为第一个参数
  5. console.log(props.foo)
  6. }
  7. }
  • 传递给 defineProps() 的参数和提供给 props 选项的值是相同的,两种声明方式背后其实使用的都是 prop 选项。

  • 除了使用字符串数组来声明 prop 外,还可以使用对象的形式,如下:

对传入的props的几种校验方式
  1. // 使用 <script setup>
  2. defineProps({
  3. title: String, // 属性名: 其对应的数据类型
  4. likes: Number,
  5. propB: [String, Number], // propB可以是字符串或者数字类型的一种
  6. propC: { // 更加详细的定义
  7. type: String, // 类型
  8. required: true// 是否必传
  9. },
  10. // Number 类型的默认值
  11. propD: {
  12. type: Number, // 类型
  13. default: 100// 指定默认值
  14. },
  15. // 对象类型的默认值
  16. propE: {
  17. type: Object, // 类型
  18. // 对象或数组的默认值
  19. // 必须从一个工厂函数返回。
  20. // 该函数接收组件所接收到的原始 prop 作为参数。
  21. default(rawProps) {
  22. return { message: 'hello' } // 对象默认值
  23. }
  24. },
  25. // 函数类型的默认值
  26. propG: {
  27. type: Function, // 类型
  28. // 不像对象或数组的默认,这不是一个工厂函数。这会是一个用来作为默认值的函数
  29. default() { // 这个直接就是一个默认函数
  30. return'Default function'
  31. }
  32. }
  33. })
  34. // 非 <script setup>
  35. export default {
  36. props: {
  37. title: String,
  38. likes: Number
  39. }
  40. }
细节总结:
  1. 所有prop默认都是可选的,可传可不传,如果声明了required: true,则该属性就是必须传的,否则警告

  1. 除 Boolean 外的未传递的可选 prop 将会有一个默认值 undefined。

  1. 布尔类型的数据未传递时prop将被转换未false,可以通过为它设置default来更改,比如说设置default:undefined与非布尔值的数据默认值相一致

传递prop的几个细节:
  1. prop的名字很长的话,应该使用小驼峰(camelCase )的形式,在传递时可以使用烤肉串(kebab-case)方式进行传递

  1. // 父组件
  2. // 传递 烤肉串方式,为了和html attribute对齐
  3. <MyComponent greeting-message="hello"/>
  4. // 子组件
  5. defineProps({
  6. greetingMessage: String // 通过小驼峰的方式接收
  7. })
  8. // 使用方面也是小驼峰的方式
  9. <span>{{ greetingMessage }}</span>
  1. 传递数据有两种,静态和动态

  • 所谓静态就是,数据直接就是死的,例如

<component-one title="爱你孤身走暗巷"></component-one> // 直接传递一个字符串
  • 动态就是先定义再传

  1. <component-one :title="title"></component-one> // 通过v-bind或者:动态绑定
  2. <script setup>
  3. import ComponentOne from '../src/components/zujianup/ComponentOne.vue'
  4. import { ref } from'vue'
  5. const title=ref('123')
  6. </script>
  1. 不同值类型的传递

  • Number

  1. <BlogPost :likes="42"/>
  2. <BlogPost :likes="post.likes"/>
  • Boolean

  1. <BlogPost is-published/> // 如果传递的数据是true时,可以直接写传递的属性名即可
  2. <BlogPost :is-published="false"/> // 传递的false需要书写完整
  3. <BlogPost :is-published="post.isPublished"/> // 传递已经定义的值
  • Array

  1. <BlogPost :comment-ids="[234, 266, 273]"/> // 直接传递一个数组
  2. <BlogPost :comment-ids="post.commentIds"/> // 传递一个存在的数组
  • Object

  1. // 和数组类似,不多做解释了
  2. <BlogPost
  3. :author="{
  4. name: 'Veronica',
  5. company: 'Veridian Dynamics'
  6. }"
  7. />
  8. <!-- 根据一个变量的值动态传入 -->
  9. <BlogPost :author="post.author"/>
  • 使用一个对象绑定多个prop

  1. // 定义
  2. const post = {
  3. id: 1,
  4. title: 'My Journey with Vue'
  5. }
  6. // 传递
  7. <component-one v-bind="post"></component-one> // 直接v-bind传递
  8. // 相当于
  9. <component-one :id="post.id" :title="post.title"></component-one>
  10. // 子组件接收 -- 分开声明,不能直接定义一个post: Oject
  11. const props = defineProps({
  12. id: Number,
  13. title: {
  14. type: String,
  15. required: true
  16. }
  17. })
单项数据流
  • props传递的数据是只读的,不可修改,否则后台会警告

  • 单项数据流的本意就是当父组件更新后,子组件的props也会跟着获取最新的值,不能去修改,如果去更改会警告

  • 对于复杂数据类型而言,虽然可以更改并且也不会警告,但也不建议这样去做

  • 这其实卡了复杂数据类型地址不变的bug,虽然可以,但也有很大的性能损耗,得不偿失

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/161192
推荐阅读
相关标签
  

闽ICP备14008679号