深入浅析Vue中的Prop


Posted in Javascript onJune 10, 2018

Prop

基本用法

Prop的基本用法很简单,只需要在子组件的Vue实例中定义该属性并把值设为目标属性的数组即可

Vue.component('child', {
 ...
 // 接收message
 props: ['message']
 ...
})

tips:由于HTML中的属性是不区分大小写的,所以当使用DOM中的模板(HTML中)时,驼峰写法需要转化为短横线写法。但是,如果使用字符串模板(JS中)时,不受限制,可以为所欲为。

Prop中的静态和动态值

在正常情况下,一般在父组件中通过v-bind定义一个动态值,子组件通过Prop接收该值,所以,很多人认为,Prop只能接收动态值。但是,其实Prop可以接受静态属性。

示例:

/* 父组件 */
<child type="video"></child>

/* 子组件 */
Vue.component('child', {
 ...
 // 成功接收
 props: ['type']
 ...
})

在示例中,父组件在子组件标签上定义了静态属性type,子组件依然通过Prop拿到了静态属性type。

单向数据流

所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父组件的 Prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父组件以及同级子组件的状态,从而导致你的应用的数据流向难以理解。

另外,每次父组件发生更新时,子组件中所有的Prop都将刷新为最新的值。这意味着你不应该在子组件内部改变Prop,如果你这样做了,Vue会在控制台抛出一个警告。

一般来说,如果子组件需要操作Prop中的值,需要将Prop中的值赋值给本地定义的属性:

...
props: ['message'],
data () {
 return {
  mes: this.message
 }
}
...

非Prop特性

非Props特性是指在组件上定义了属性,而又没有使用Prop接受属性。此时,子组件内不可使用该属性值,该属性会直接添加到子组件的根节点上。

比如,在一个只含有一个div的子组件上,如果我向子组件传了一个content属性,但是子组件不使用Prop接收content属性,则渲染结果为:

<div id="root">
  <div content="hello"></div>
</div>

Prop校验

子组件用Props接收父组件传来的消息有多种形式:

1.数组形式

props: [data1, data2]

数组形式相当于直接接收消息,不做任何校验,一般来说,不太建议使用数组形式。

2.简单对象形式

props: {
 data1: String,
 data2: Array
}

简单对象形式对父组件传递的值进行了类型校验,如果传过来的值类型不一致,控制台会报错。

3.复杂对象形式

props: {
 data1: {
  type: String,
  required: true,
  default: 'default value',
  validator (value) {
   return (value.length < 5)
  }
 },
 data2: {
  type: Array,
  required: true,
  default: () => ['', '', '']
 }
}

复杂对象形式的情况下,作为对象属性的参数可以写为对象形式,参数对象含有4个属性,type、required、default、validator。

type:设定参数类型,当传入参数类型与type不相符时,控制台会报错

required:设定参数是否是必传,当设为true时,不传该参数会报错

default:设定默认值,当参数类型为复杂类型时,需使用工厂模式生成默认值,否则Vue会在控制台抛出警告。如图所示,就通过工厂模式生成了一个长度为3的空数组。

validator:校验器,是一个函数,拥有一个代表传入值的形参,可以自定义各种校验,当返回false时,会报错,表示没通过校验。

Javascript 相关文章推荐
11款新鲜的jQuery插件[附所有demo下载]
Jan 24 Javascript
JQuery实现倒计时按钮的实现代码
Mar 23 Javascript
JQuery的read函数与js的onload不同方式实现
Mar 18 Javascript
高效的获取当前元素是父元素的第几个子元素
Oct 15 Javascript
jquery设置text的值示例(设置文本框 DIV 表单值)
Jan 06 Javascript
JavaScript实现使用Canvas绘制图形的基本教程
Oct 27 Javascript
Node.js的特点详解
Feb 03 Javascript
详解Angular-cli生成组件修改css成less或sass的实例
Jul 27 Javascript
微信小程序上传图片功能(附后端代码)
Jun 19 Javascript
jQuery位置选择器用法实例分析
Jun 28 jQuery
详解nuxt 微信公众号支付遇到的问题与解决
Aug 26 Javascript
js实现自动锁屏功能
Jun 02 Javascript
vue项目部署上线遇到的问题及解决方法
Jun 10 #Javascript
js技巧之十几行的代码实现vue.watch代码
Jun 09 #Javascript
浅谈JS对象添加getter与setter的5种方法
Jun 09 #Javascript
让你5分钟掌握9个JavaScript小技巧
Jun 09 #Javascript
jQuery基于闭包实现的显示与隐藏div功能示例
Jun 09 #jQuery
JS实现区分中英文并统计字符个数的方法示例
Jun 09 #Javascript
详解angular脏检查原理及伪代码实现
Jun 08 #Javascript
You might like
全国FM电台频率大全 - 11 浙江省
2020/03/11 无线电
php中的实现trim函数代码
2007/03/19 PHP
php下连接mssql2005的代码
2011/01/17 PHP
解析:使用php mongodb扩展时 需要注意的事项
2013/06/18 PHP
php可生成缩略图的文件上传类实例
2014/12/17 PHP
PHP使用PDO连接ACCESS数据库
2015/03/05 PHP
详解PHP swoole process的使用方法
2017/08/26 PHP
js获取url中指定参数值的示例代码
2013/12/14 Javascript
javascript实现表格排序 编辑 拖拽 缩放
2015/01/02 Javascript
angularJS 中$scope方法使用指南
2015/02/09 Javascript
jQuery实现获取table表格第一列值的方法
2016/03/01 Javascript
JS继承之借用构造函数继承和组合继承
2016/09/07 Javascript
smartupload实现文件上传时获取表单数据(推荐)
2016/12/12 Javascript
vue2实现可复用的轮播图carousel组件详解
2017/11/27 Javascript
详解vue文件中使用echarts.js的两种方式
2018/10/18 Javascript
微信小程序tabbar底部导航
2018/11/05 Javascript
读懂CommonJS的模块加载
2019/04/19 Javascript
angular4应用中输入的最小值和最大值的方法
2019/05/17 Javascript
详解ES6 扩展运算符的使用与注意事项
2020/11/12 Javascript
JavaScript实现原型封装轮播图
2020/12/27 Javascript
python实现Decorator模式实例代码
2018/02/09 Python
Python容器使用的5个技巧和2个误区总结
2019/09/26 Python
python实现实时视频流播放代码实例
2020/01/11 Python
python随机模块random的22种函数(小结)
2020/05/15 Python
Python matplotlib模块及柱状图用法解析
2020/08/10 Python
CSS3实现水平居中、垂直居中、水平垂直居中的实例代码
2020/02/27 HTML / CSS
Lands’ End官网:经典的美国生活方式品牌
2016/08/14 全球购物
美国在线家具网站:GDFStudio
2021/03/13 全球购物
初中音乐教学反思
2014/01/12 职场文书
情人节活动策划方案
2014/02/27 职场文书
小区推广策划方案
2014/06/06 职场文书
校园元旦活动总结
2014/07/09 职场文书
清洁工岗位职责
2015/02/13 职场文书
房屋维修申请报告
2015/05/18 职场文书
教师年度考核自我评鉴
2015/08/11 职场文书
大学班干部竞选稿
2015/11/20 职场文书