vue props
来源:互联网 发布:楠楠广场舞网络一线牵 编辑:程序博客网 时间:2024/05/17 00:52
#props
用于接收来自父组件的数据(子组件期待获得的数据)
类型:字符串数组或者object
e.g.
数组:props: ['size', 'myMessage']对象: props: { // 只检测类型 height: Number, // 检测类型 + 其他验证 age: { type: Number, default: 0, required: true, validator: function (value) { return value >= 0 } } }
HTML 特性是不区分大小写的。所以,当使用的不是字符串模板,camelCased(驼峰式) 命名的 prop 需要转换为相对应的 kebab-case(短横线隔开式) 命名:
父组件:
<!-- kebab-case in HTML --><child my-message="hello!"></child>子组件:
// camelCase in JavaScript props: ['myMessage'],
#动态Prop
要动态地绑定父组件的数据到子模板的 props需要使用v-bind,这样每当父组件的数据变化时,该变化也会传导给子组件。
#字面量语法vs动态语法
父组件:
<!-- 传递了一个字符串 "1" --><comp some-prop="1"></comp>
=右边是字符串”1”而不是number。如果想要传递一个number,需要使用v-bind,从而让它的值被当作js表达式计算
<!-- 传递实际的 number --><comp v-bind:some-prop="1"></comp>
字面量分为字符串字面量(string literal )、数组字面量(array literal)和对象字面量(object literal),另外还有函数字面量(function literal)。
Prop中的数据
1.prop 作为初始值传入后,子组件想把它当作局部数据来用;
定义一个局部变量,并用 prop 的值初始化它:
子组件:
props: ['initialCounter'],data: function () { return { counter: this.initialCounter }}
2.prop 作为初始值传入,由子组件处理成其它数据输出。
定义一个计算属性,处理 prop 的值并返回。
子组件:
props: ['size'],computed: { normalizedSize: function () { return this.size.trim().toLowerCase() }}
注意在 JavaScript 中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态。
#prop验证
子组件:props: { // 基础类型检测 (`null` 意思是任何类型都可以) propA: Number, // 多种类型 propB: [String, Number], // 必传且是字符串 propC: { type: String, required: true }, // 数字,有默认值 propD: { type: Number, default: 100 }, // 数组/对象的默认值应当由一个工厂函数返回 propE: { type: Object, default: function () { return { message: 'hello' } } }, // 自定义验证函数 propF: { validator: function (value) { return value > 10 } } }
注意 props 会在组件实例创建之前进行校验,所以在 default 或 validator 函数里,诸如 data、computed 或 methods 等实例属性还无法使用。
#非父子组件通信
有时候两个组件也需要通信 (非父子关系)。在简单的场景下,可以使用一个空的 Vue实例作为中央事件总线:
var bus = new Vue()
// 触发组件 A 中的事件bus.$emit('id-selected', 1)
// 在组件 B 创建的钩子中监听事件bus.$on('id-selected', function (id) { // ...})
- vue props
- Vue之props属性
- vue props 取名问题
- Vue组件选项props
- vue中props传值
- Vue父子通信 props
- Vue props用法总结
- Vue的Props属性概述
- vue.js ——props
- vue props怎么传多个数据?
- Vue 父子通信(props,$.emit( ) )
- vue.js使用props传递数据
- vue中component组件的props使用
- Vue- 组件与props属性的用法
- Vue-组件props属性再回顾
- vue组件3-父子组件props传参
- vue组件4-props传参2
- vue 分页组件及props传参
- DataTable插件Hello world
- 代码重构(五):继承关系重构规则
- PHP的continue、break、goto、exit和die的用法
- Java基础恶补——内存泄露、内存溢出
- Error in plot.new() : figure margins too large
- vue props
- C/C++:各种基本算法实现小结(七)—— 常用算法
- dsi_set_cmdq 用法
- 【POJ2449】Remmarguts' Date(A*搜索)
- jquery.dataTables 按条件查询后重新生成表格 点击排序还是原来的数据问题
- LeetCode5—Longest Palindromic Substring
- pat 乙级 1034. 有理数四则运算(20)
- 代码重构(六):代码重构完整案例
- luogu1073 【noip2009提高】最优贸易(spfa)