时间:2021-05-26
子组件接收父组件的参数的时候,props注册接收的参数
props:['count']子组件可以对接收的参数校验。
例如规定接收的count参数要求是String
props:{count:String}如果count是别的类型就会报错
组件的参数校验
组件的参数校验指的是什么呢?你父组件向子组件传递的内容,子组件有权对这个内容进行一些约束,这个约束我们可以把它叫做参数的校验。
<div id="root"> <child content="hello world"></child></div>Vue.component('child',{ props: ['content'], template: '<div>{{content}}</div>'})let vm = new Vue({ el: '#root',})现在有这样一个需求,父组件调用子组件的时候,传递的这个content,我要做一些约束,要求它我传递过来的content必须是一个字符串,我们该怎么实现呢?
<div id="root"> <child content="hello world"></child></div>Vue.component('child',{ props: { content: String //子组件接收到的 content 这个属性,必须是一个字符串类型的 }, template: '<div>{{content}}</div>'})let vm = new Vue({ el: '#root',})组件接收到的content这个属性,必须是一个字符串类型的,如果我需要的参数类型是字符串或者数组,又该怎么写呢?
props: { content: [ String, Number ]},content的类型,可以用数组来表示。
content其实还有更复杂的用法:
props: { content: { type: Sring, required: true, //必传 default: 'default value', //默认显示,非必传会显示 validator(value){ //检测 content 的长度,如果长度大于 5,正常显示,如果长度小于 5 则报错 return (value.length > 5) } }}非props特性
说到非props特性,它一定和props特性相对应。
props特性:当你的父组件使用子组件的时候,通过属性向子组件传值的时候,恰好子组件里面声明了对父组件传递过来的属性的一个接收,也就是说父子组件有个对应关系,如果你这么写我们就把叫做props特性
props特性的特点是,如下图:
非props特性:父组件向子组件传递了一个属性,但是子组件并没有props这块的内容,也就是说子组件并没有声明我要接收父组件的传递过来的内容
非props特点:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Vue常用传值方式、父传子、子传父及非父子。分享给大家供大家参考,具体如下:父组件向子组件传值是利用props子组件中的注意事项:props:[‘
本文介绍了vue中component组件的props使用详解,分享给大家,具体如下:props使用方法Vue.component('my-component',
组件传参通过给组件传递参数,可以让组件变得更加可扩展,组件内使用props接收参数exportdefault{props:['options'],data(){
最近面试,被问到一个题目,vue做一个按钮组件;当时只是说了一下思路,回来就附上代码。解决思路:通过父子组件通讯($refs和props)props接受参数,$
Vue是一个轻量级的渐进式框架,对于它的一些特性和优点在此就不做赘述。下面通过本文给大家分享Vue中父组件向子组件通信的方法,具体内容详情如下所示:props组