• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Custom Components
2
3
4The ArkUI that uses the JavaScript-based web-like development paradigm supports custom components for you to extend existing components. You can encapsulate custom private attributes and events into new components to reuse them multiple times in your project. This also improves code readability. The following is an example:
5
6
7- Building a custom component
8
9  ```html
10  <!-- comp.hml -->
11   <div class="item">
12     <text class="title-style">{{title}}</text>
13     <text class="text-style" onclick="childClicked" focusable="true">Click to view the hidden text.</text>
14     <text class="text-style" if="{{showObj}}">hello world</text>
15   </div>
16  ```
17
18  ```css
19  /* comp.css */
20   .item {
21     width: 700px;
22     flex-direction: column;
23     height: 300px;
24     align-items: center;
25     margin-top: 100px;
26   }
27   .text-style {
28     width: 100%;
29     text-align: center;
30     font-weight: 500;
31     font-family: Courier;
32     font-size: 36px;
33   }
34   .title-style {
35     font-weight: 500;
36     font-family: Courier;
37     font-size: 50px;
38     color: #483d8b;
39   }
40  ```
41
42  ```js
43  // comp.js
44   export default {
45     props: {
46       title: {
47         default: 'title',
48       },
49       showObject: {},
50     },
51     data() {
52       return {
53         showObj: this.showObject,
54       };
55     },
56     childClicked () {
57       this.$emit('eventType1', {text: 'Receive the parameters from the child component.'});
58       this.showObj = !this.showObj;
59     },
60   }
61  ```
62
63- Introducing the custom component
64
65  ```html
66  <!-- xxx.hml -->
67   <element name='comp' src='../../common/component/comp.hml'></element>
68   <div class="container">
69     <text>Parent component: {{text}}</text>
70     <comp title="Custom component" show-object="{{isShow}}" @event-type1="textClicked"></comp>
71   </div>
72  ```
73
74  ```css
75  /* xxx.css */
76   .container {
77     background-color: #f8f8ff;
78     flex: 1;
79     flex-direction: column;
80     align-content: center;
81   }
82  ```
83
84  ```js
85  // xxx.js
86   export default {
87     data: {
88       text: 'Start'
89       isShow: false,
90     },
91     textClicked (e) {
92       this.text = e.detail.text;
93     },
94   }
95  ```
96
97
98In this example, the parent component passes the customized attribute through title to the child component, and the child component receives the attribute value in props. The child component passes text to the parent through the bound event, and the passed value is obtained via e.detail. To successfully bind the child component event to the parent component, ensure that the event name meet the requirements for event binding. For details, see [Basic Usage of Custom Components](../reference/arkui-js/js-components-custom-basic-usage.md). The following figures show how the custom component works.
99
100**Figure 1** Running effect
101
102![en-us_image_0000001222807816](figures/en-us_image_0000001222807816.png)
103