文章目录

  • vue中的props
  • Props命名格式:
  • prpos特点:
  • 1.单项数据流
  • 2.两种方式
  • 3.限制数值类型,默认值,必填项,
  • 基本使用方法:父组件向子组件传值
  • 传静态的值
  • 传动态值
  • 传递不同值类型:
  • Number (数字类型)
  • Boolean(布尔类型)
  • Array(数组类型)
  • Object(对象类型)



vue中的props

Props命名格式:

vue官网中表示:

如果一个 prop 的名字很长,应使用 camelCase(驼峰命名法) 形式,因为它们是合法的 JavaScript 标识符,可以直接在模板的表达式中使用,也可以避免在作为属性 key 名时必须加上引号。

虽然理论上你也可以在向子组件传递 props 时使用 camelCase 形式 (使用 DOM 模板时例外),但实际上为了和 HTML attribute 对齐,我们通常会将其写为 kebab-case(短横线分割式) 形式

prpos特点:
1.单项数据流

这意味着你不应该在子组件中去更改一个 prop

这个是什么意思呢,是这样的,欸,我拿到值了,就不能直接去修改props 里面的值,

这个问题怎么解决呢,就是在data重新定义一个值去接收这个值

官网文档

export default {
  props: ['initialCounter'],
  data() {
    return {
      // 计数器只是将 this.initialCounter 作为初始值
      // 像下面这样做就使 prop 和后续更新无关了
      counter: this.initialCounter
    }
  }
}
2.两种方式

在props中 可以使用两种格式接收值,一个是数组的形式,一种是对象的形式

这个是使用数组的方式接收

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SjuWv86N-1682557114102)(C:\Users\dell\Desktop\微信截图_20230426201254.png)]

这个是使用数组的方式接收

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hfSAv1uS-1682557114103)(C:\Users\dell\Desktop\微信截图_20230426201417.png)]

3.限制数值类型,默认值,必填项,

在使用 对象方式接收值的时候,可以设置限制数值类型,默认值,必填项,

父组件:

<template>
  <div id="app">
    <hello-world :age='age' :sex='sex' :name='name'></hello-world>
  </div>
</template>

<script>
import HelloWorld from './my-son.vue'

export default {
  data() {
    return {
      name: '张三',
      age: 18,
      sex:'男'
    }
  },
  components: {
    HelloWorld
  }
}
</script>

子组件:

<template>
  <h1>{{name}}</h1>
  <h1>{{sex}}</h1>
  <h1>{{age}}</h1>
</template>

<script>
export default {
  props: {
    name: {
      type: String, //设置数值类型是字符串
      required: true //设置name 为必填项
    },
    sex: {
      type: String,
      default: '男' //设置 sex 的默认值是 男 当sex没有是会默认为男
    },
    age: String
  }
}
</script>
基本使用方法:父组件向子组件传值

我在刚开始学习的时候,总是习惯,在父组件的标签里面写v-bind。其实应该在子组件里使用v-bind

传静态的值

父组件:

<template>
  <div id="app">
    <hello-world msg="'你好'"></hello-world>
  </div>
</template>

<script>
    
import HelloWorld from './my-son.vue'

export default {
  components: {
    HelloWorld
  }
}
</script>

子组件:

<template>
  <h1>{{msg}}</h1>
</template>

<script>
export default {
  props: ['msg']
}
</script>
传动态值

相应地,还有使用 v-bind 或缩写 : 来进行动态绑定的 props:

父组件

<template>
  <div id="app">
     <!-- 根据一个变量的值动态传入 -->
    <hello-world :msg="title"></hello-world>
  </div>
</template>

<script>
import HelloWorld from './my-son.vue'

export default {
  data(){
    return{
      title:'你好'
    }
  },
  components: {
    HelloWorld
  }
}
</script>

这里子组件没有改动

传递不同值类型:

上面的案例都是传入的字符串类的值,其实props可以传 任何的值

Number (数字类型)
<hello-world msg="42"></hello-world>
Boolean(布尔类型)

父组件:

<template>
  <div id="app">
    <hello-world :msg="title"></hello-world>
  </div>
</template>

<script>
import HelloWorld from './my-son.vue'

export default {
  data() {
    return {
      title: false  //我们使用动态传值的方式 ,传递一个布尔值过去
    }
  },
  components: {
    HelloWorld
  }
}
</script>

子组件:

<template>
  <h1>{{msg}}</h1>
	<!-- 这里使用全等进行判断,如拿到的值是布尔值的true这个div就会展示出来 -->
  <div v-if=" msg === true">true展示</div>
	<!-- 但是这里拿到的值是 布尔值的false 所以不会展示出来 -->
</template>

<script>
export default {
  props: ['msg']
}
</script>
Array(数组类型)

父组件:

<template>
  <div id="app">
    <hello-world :msg="title"></hello-world>
  </div>
</template>

<script>
import HelloWorld from './my-son.vue'

export default {
  data() {
    return {
        //使用动态传值的方式,定义一个数组
      title: ['第一项', '第二项', '第三项']
    }
  },
  components: {
    HelloWorld
  }
}
</script>

子组件:

<template>
  <h1>{{msg}}</h1>
  <ul>
    <li v-for="item in msg" key="item">{{item}}</li>
  </ul>
</template>

<script>
export default {
  props: ['msg']
}
</script>
Object(对象类型)

父组件:

<template>
  <div id="app">
    <hello-world :msg="title"></hello-world>
  </div>
</template>

<script>
import HelloWorld from './my-son.vue'

export default {
  data() {
    return {
      title:{
        name:'张三',
        age:18
      }
    }
  },
  components: {
    HelloWorld
  }
}
</script>

子组件:

<template>
  <h1>{{msg}}</h1>
  <h1>{{msg.name}}</h1>
  <h1>{{msg.age}}</h1>
</template>

<script>
export default {
  props: ['msg']
}
</script>
return {
 title:{
 name:‘张三’,
 age:18
 }
 }
 },
 components: {
 HelloWorld
 }
 }
**子组件:**

```vue
<template>
  <h1>{{msg}}</h1>
  <h1>{{msg.name}}</h1>
  <h1>{{msg.age}}</h1>
</template>

<script>
export default {
  props: ['msg']
}
</script>