• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 基本用法
2
3自定义组件是用户根据业务需求,将已有的组件组合,封装成的新组件,可以在工程中多次调用,从而提高代码的可读性。自定义组件通过element引入到宿主页面,使用方法如下:
4```
5<element name='comp' src='../../common/component/comp.hml'></element>
6<div>
7  <comp prop1='xxxx' @child1="bindParentVmMethod"></comp>
8</div>
9```
10
11
12结合if-else使用自定义组件的示例:
13```
14<element name='comp1' src='../../common/component/comp1/comp1.hml'></element>
15<element name='comp2' src='../../common/component/comp2/comp2.hml'></element>
16<div>
17  <comp1 if="{{showComp1}}" prop1='xxxx' @child1="bindParentVmMethodOne"></comp1>
18  <comp2 else prop1='xxxx' @child1="bindParentVmMethodTwo"></comp2>
19</div>
20```
21
22
23- name属性指自定义组件名称(非必填),组件名称对大小写不敏感,默认使用小写。src属性指自定义组件hml文件路径(必填),若没有设置name属性,则默认使用hml文件名作为组件名。
24
25- 事件绑定:自定义组件中绑定子组件事件使用(on|@)child1语法,子组件中通过this.$emit('child1', { params: '传递参数' })触发事件并进行传值,父组件执行bindParentVmMethod方法并接收子组件传递的参数。
26  > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
27  > 子组件中使用驼峰命名法命名的事件,在父组件中绑定时需要使用短横线分隔命名形式,例如:\@children-event表示绑定子组件的childrenEvent事件,如 \@children-event="bindParentVmMethod"。
28
29**表1** 对象
30
31| 属性 | 类型 | 描述 |
32| -------- | -------- | -------- |
33| data | Object/Function | 页面的数据模型,类型是对象或者函数,如果类型是函数,返回值必须是对象。属性名不能以$或_开头,不要使用保留字for,&nbsp;if,&nbsp;show,&nbsp;tid。<br/>data与private和public不能重合使用。(Rich) |
34| props | Array/Object | props用于组件之间的通信,可以通过&lt;tag&nbsp;xxxx='value'&gt;方式传递给组件;props名称必须用小写,不能以$或_开头,不要使用保留字for,&nbsp;if,&nbsp;show,&nbsp;tid。目前props的数据类型不支持Function。 |
35| computed | Object | 计算属性,用于在读取或设置时,进行预先处理,其结果会被缓存。计算属性名不能以$或_开头,不要使用保留字。 |
36