• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# search
2
3
4提供搜索框组件,用于提供用户搜索内容的输入区域,具体用法请参考[search](../reference/arkui-js/js-components-basic-search.md)。
5
6
7## 创建search组件
8
9pages/index目录下的hml文件中创建一个search组件。
10
11
12```html
13<!-- xxx.hml-->
14<div class="container">
15  <search></search>
16</div>
17```
18
19
20```css
21/* xxx.css */
22.container {
23  width: 100%;
24  height: 100%;
25  flex-direction: column;
26  align-items: center;
27  justify-content: center;
28  background-color: #F1F3F5;
29}
30```
31
32![zh-cn_image_0000001218760480](figures/zh-cn_image_0000001218760480.png)
33
34
35## 设置属性
36
37通过设置hint、icon和searchbutton属性设置搜索框的提示文字、图标和末尾搜索按钮的内容。
38
39
40```html
41<!-- xxx.hml-->
42<div class="container">
43  <search hint="Please enter the search content"  searchbutton="search" icon="/common/search1.png"></search>
44</div>
45```
46
47
48```css
49/* xxx.css */
50.container {
51  width: 100%;
52  height: 100%;
53  flex-direction: column;
54  align-items: center;
55  justify-content: center;
56  background-color: #F1F3F5;
57}
58```
59
60![zh-cn_image_0000001183438596](figures/zh-cn_image_0000001183438596.png)
61
62
63## 添加样式
64
65通过color、placeholder-color和caret-color样式来设置搜索框的文本颜色、提示文本颜色和光标颜色。
66
67
68```html
69<!-- xxx.hml-->
70<div class="container">
71  <search hint="Please enter the search content"  searchbutton="search" ></search>
72</div>
73```
74
75
76```css
77/* xxx.css */
78.container {
79  width: 100%;
80  height: 100%;
81  flex-direction: column;
82  align-items: center;
83  justify-content: center;
84  background-color: #F1F3F5;
85}
86search{
87  color: black;
88  placeholder-color: black;
89  caret-color: red;
90}
91```
92
93![zh-cn_image_0000001228920921](figures/zh-cn_image_0000001228920921.gif)
94
95
96## 绑定事件
97
98向search组件添加change、search、submit、share和translate事件,对输入信息进行操作。
99
100
101```html
102<!-- xxx.hml-->
103<div class="container">
104  <text style="margin-left: -7px;">
105    <span>Enter text and then touch and hold what you've entered</span>
106  </text>
107  <search hint="Please enter the search content"  searchbutton="search" onsearch="search" onchange="change" ontranslate="translate" onshare="share"
108  onsubmit="submit">
109  </search>
110</div>
111```
112
113
114```css
115/* xxx.css */
116.container {
117  width: 100%;
118  height: 100%;
119  flex-direction: column;
120  align-items: center;
121  justify-content: center;
122  background-color: #F1F3F5;
123}
124text{
125  width: 100%;
126  font-size: 25px;
127  text-align: center;
128  margin-bottom: 100px;
129}
130```
131
132
133```js
134// index.js
135import promptAction from '@ohos.promptAction'
136export default {
137  search(e){
138    promptAction.showToast({
139      message:  e.value,
140      duration: 3000,
141    });
142  },
143  translate(e){
144    promptAction.showToast({
145      message:  e.value,
146      duration: 3000,
147    });
148  },
149  share(e){
150    promptAction.showToast({
151      message:  e.value,
152      duration: 3000,
153    });
154  },
155  change(e){
156    promptAction.showToast({
157      message:  e.value,
158      duration: 3000,
159    });
160  },
161  submit(e){
162    promptAction.showToast({
163      message: 'submit',
164      duration: 3000,
165    });
166  }
167}
168```
169
170![zh-cn_image_0000001182187434](figures/zh-cn_image_0000001182187434.gif)
171
172
173## 场景示例
174
175在本场景中通过下拉菜单选择search、Textarea和Input组件来实现搜索和输入效果。
176
177
178```html
179<!-- xxx.hml-->
180<div style="flex-direction: column;align-items: center;justify-content: center; width: 100%;">
181  <select class="slt1" id="slt1" onchange="setfield">
182    <option value="search">search</option>
183    <option value="textarea">Textarea</option>
184    <option value="input">Input</option>
185  </select>
186  <div if="{{showsearch}}" style="flex-direction: column;align-items: center;margin-top: 50px;height: 400px;justify-content: space-around;">
187    <search class="field" id="search1" hint="search1" onsubmit="submit" onchange="change" ></search>
188    <search class="field" id="search2" icon="common/search1.png" hint="search2" show="{{showsec}}" onsubmit="submit" onchange="change" ></search>
189  </div>
190  <div if="{{showtextarea}}" style="flex-direction: column;align-items: center;margin-top: 50px;height: 400px;justify-content: space-around;">
191    <textarea class="field" id="textarea1" extend="true" placeholder="textarea1" onchange="change" ></textarea>
192    <textarea class="field" id="textarea2" extend="true" placeholder="textarea2" onchange="change" show="{{showsec}}"></textarea>
193  </div>
194  <div if="{{showinput}}" style="flex-direction: column;align-items: center;margin-top: 50px;height: 400px;justify-content: space-around;">
195    <input type="text" class="field" id="input1" placeholder="input1" onchange="change" ></input>
196    <input type="text" class="field" id="input2" placeholder="input2" onchange="change" show="{{showsec}}"></input>
197  </div>
198</div>
199```
200
201
202```css
203/* xxx.css */
204.field {
205  width: 80%;
206  color: mediumaquamarine;
207  font-weight: 600;
208  placeholder-color: orangered;
209}
210.slt1{
211  font-size: 50px;
212  position: absolute;
213  left: 50px;
214  top: 50px;
215}
216```
217
218
219```js
220// index.js
221import promptAction from '@ohos.promptAction';
222export default {
223  data: {
224    showsearch: true,
225    showtextarea: false,
226    showinput: false,
227    showsec: true,
228  },
229  setfield(e) {
230    this.field = e.newValue
231    if (e.newValue == 'search') {
232      this.showsearch = true
233      this.showtextarea = false
234      this.showinput = false
235    } else if (e.newValue == 'textarea') {
236      this.showsearch = false
237      this.showtextarea = true
238      this.showinput = false
239    } else {
240      this.showsearch = false
241      this.showtextarea = false
242      this.showinput = true
243    }
244  },
245  submit(e) {
246    promptAction.showToast({
247      message: '搜索!',
248      duration: 2000
249    })
250  },
251  change(e) {
252    promptAction.showToast({
253      message: '内容:' + e.text,
254      duration: 2000
255    })
256  }
257}
258```
259
260![zh-cn_image_0000001183283966](figures/zh-cn_image_0000001183283966.gif)
261