• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# textarea
2<!--Kit: ArkUI-->
3<!--Subsystem: ArkUI-->
4<!--Owner: @kangshihui-->
5<!--Designer: @pssea-->
6<!--Tester: @jiaoaozihao-->
7<!--Adviser: @HelloCrease-->
8
9>  **说明:**
10>  从API version 4开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
11
12多行文本输入的文本框。
13
14
15## 权限列表
16
1718
19
20## 子组件
21
22不支持。
23
24
25## 属性
26
27除支持[通用属性](js-components-common-attributes.md)外,还支持如下属性:
28
29| 名称                             | 类型                    | 默认值 | 必填 | 描述                                                         |
30| -------------------------------- | ----------------------- | ------ | ---- | ------------------------------------------------------------ |
31| placeholder                      | string                  | -      | 否   | 多行文本框的提示文本内容。                                   |
32| maxlength                        | number                  | -      | 否   | 多行文本框可输入的最多字符数量。                             |
33| headericon                       | string                  | -      | 否   | 在文本输入前的图标展示,该图标不支持点击事件,图标格式为jpg,png和svg。 |
34| extend                           | boolean                 | false  | 否   | 文本框是否支持可扩展,true表示文本框支持可扩展,false表示文本框不支持可扩展。设置可扩展属性后文本框高度可以跟随文字自适应。 |
35| value<sup>5+</sup>               | string                  | -      | 否   | 多行文本框的内容。                                           |
36| showcounter<sup>5+</sup>         | boolean                 | false  | 否   | 文本框是否需要开启计数下标功能,需要配合maxlength一起使用。true表示文本框开启计数下标,false表示文本框不开启计数下标。  |
37| menuoptions<sup>5+</sup>         | Array&lt;MenuOption&gt; | -      | 否   | 设置文本选择弹框点击更多按钮之后显示的菜单项。               |
38| autofocus<sup>6+</sup>           | boolean                 | false  | 否   | 是否自动获焦。true表示文本框自动获焦,false表示文本框不自动获焦。                                               |
39| selectedstart<sup>6+</sup>       | number                  | -1     | 否   | 开始选择文本时初始选择位置。                                 |
40| selectedend<sup>6+</sup>         | number                  | -1     | 否   | 开始选择文本时结尾选择位置。                                 |
41| softkeyboardenabled<sup>6+</sup> | boolean                 | true   | 否   | 编辑时是否弹出系统软键盘。true表示编辑时弹出系统软键盘,false表示不弹出。                                   |
42
43**表1** MenuOption<sup>5+</sup>
44
45| 名称      | 类型     | 描述          |
46| ------- | ------ | ----------- |
47| icon    | string | 菜单选项中的图标路径。 |
48| content | string | 菜单选项中的文本内容。 |
49
50
51## 样式
52
53除支持[通用样式](js-components-common-styles.md)外,还支持如下样式:
54
55| 名称                       | 类型                         | 默认值        | 必填   | 描述                                       |
56| ------------------------ | -------------------------- | ---------- | ---- | ---------------------------------------- |
57| color                    | &lt;color&gt;              | \#e6000000 | 否    | 多行文本框的文本颜色。                              |
58| font-size                | &lt;length&gt;             | 16px       | 否    | 多行文本框的文本尺寸。                              |
59| allow-scale              | boolean                    | true       | 否    | 多行文本框的文本尺寸是否跟随系统设置字体缩放尺寸进行放大缩小。true表示跟随系统放大缩小,false表示不跟随系统放大缩小。<br/>如果在config描述文件中针对ability配置了fontSize的config-changes标签,则应用不会重启而直接生效。 |
60| placeholder-color        | &lt;color&gt;              | \#99000000 | 否    | 多行文本框的提示文本颜色,type为text\|email\|date\|time\|number\|password时生效。 |
61| font-weight              | number&nbsp;\|&nbsp;string | normal     | 否    | 多行文本框的字体粗细,见[text组件font-weight的样式属性](js-components-basic-text.md#样式)。 |
62| font-family              | string                     | sans-serif | 否    | 多行文本框的字体列表,用逗号分隔,每个字体用字体名或者字体族名设置。列表中第一个系统中存在的或者通过[自定义字体](js-components-common-customizing-font.md)指定的字体,会被选中作为文本的字体。 |
63| caret-color<sup>6+</sup> | &lt;color&gt;              | -          | 否    | 设置输入光标的颜色。                               |
64
65
66## 事件
67
68除支持[通用事件](js-components-common-events.md)外,还支持如下事件:
69
70| 名称                        | 参数                                       | 描述                                       |
71| ------------------------- | ---------------------------------------- | ---------------------------------------- |
72| change                    | {&nbsp;text:&nbsp;newText,&nbsp;lines:&nbsp;textLines,&nbsp;height:&nbsp;textHeight&nbsp;} | 输入内容发生变化时触发该事件,通过参数获取输入内容、行数和行高。<br/>从API Version 5开始,改变value属性值不会触发该回调。 |
73| translate<sup>5+</sup>    | {&nbsp;value:&nbsp;selectedText&nbsp;}   | 设置此事件后,进行文本选择操作后文本选择弹窗会出现翻译按钮,点击翻译按钮之后,触发该回调,返回选中的文本内容。 |
74| share<sup>5+</sup>        | {&nbsp;value:&nbsp;selectedText&nbsp;}   | 设置此事件后,进行文本选择操作后文本选择弹窗会出现分享按钮,点击分享按钮之后,触发该回调,返回选中的文本内容。 |
75| search<sup>5+</sup>       | {&nbsp;value:&nbsp;selectedText&nbsp;}   | 设置此事件后,进行文本选择操作后文本选择弹窗会出现搜索按钮,点击搜索按钮之后,触发该回调,返回选中的文本内容。 |
76| optionselect<sup>5+</sup> | {&nbsp;index:optionIndex,&nbsp;value:&nbsp;selectedText&nbsp;} | 文本选择弹窗中设置menuoptions属性后,用户在文本选择操作后,点击菜单项后触发该回调,返回点击的菜单项序号和选中的文本内容。 |
77| selectchange<sup>6+</sup> | {&nbsp;start:&nbsp;number,end:&nbsp;number&nbsp;} | 文本选择变化时触发事件。                             |
78
79
80## 方法
81
82支持[通用方法](js-components-common-methods.md)。
83
84
85## 示例
86
87```html
88<!-- xxx.hml -->
89<textarea id="textarea" class="textarea" extend="true" maxlength="20"
90  headericon="/common/navigation_menu1_icon.svg" placeholder="Please input text"
91  onchange="change">
92</textarea>
93```
94
95```css
96/* xxx.css */
97.textarea {
98  placeholder-color: gray;
99}
100```
101
102```js
103// xxx.js
104import promptAction from '@ohos.promptAction';
105export default {
106change(e){
107  promptAction.showToast({
108    message: 'value: ' + e.text + ', lines: ' + e.lines + ', height: ' + e.height,
109    duration: 3000,
110  });
111}
112}
113```
114
115![zh-cn_image_0000001127125124](figures/zh-cn_image_0000001127125124.png)
116