# text开发指导 text是文本组件,用于呈现一段文本信息。具体用法请参考[text API](../reference/arkui-js/js-components-basic-text.md)。 ## 创建text组件 在pages/index目录下的hml文件中创建一个text组件。 ```html
Hello World
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; align-items: center; justify-content: center; background-color: #F1F3F5; } ``` ![zh-cn_image_0000001211383427](figures/zh-cn_image_0000001211383427.png) ## 设置text组件样式和属性 - 添加文本样式 设置color、font-size、allow-scale、word-spacing、text-valign属性分别为文本添加颜色、大小、缩放、文本之间的间距和文本在垂直方向的对齐方式。 ```html
This is a passage This is a passage
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; align-items: center; justify-content: center; background-color: #F1F3F5; } ``` ![zh-cn_image_0000001220778205](figures/zh-cn_image_0000001220778205.png) - 添加划线 设置text-decoration和text-decoration-colo属性为文本添加划线和划线颜色,text-decoration枚举值请参考 text自有样式。 ```html
This is a passage This is a passage
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; align-items: center; justify-content: center; } text{ font-size: 50px; } ``` ![zh-cn_image_0000001220856725](figures/zh-cn_image_0000001220856725.png) - 隐藏文本内容 当文本内容过多而显示不全时,添加text-overflow属性将隐藏内容以省略号的形式展现。 ```html
This is a passage
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; flex-direction: column; align-items: center; background-color: #F1F3F5; justify-content: center; } .text{ width: 200px; max-lines: 1; text-overflow:ellipsis; } ``` > **说明:** > - text-overflow样式需要与max-lines样式配套使用,设置了最大行数的情况下生效。 > - max-lines属性设置文本最多可以展示的行数。 ​ ![zh-cn_image_0000001163656706](figures/zh-cn_image_0000001163656706.png) - 设置文本折行 设置word-break属性对文本内容做断行处理,word-break枚举值请参考text自有样式。 ```html
Welcome to the world Welcome to the world
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; background-color: #F1F3F5; flex-direction: column; align-items: center; justify-content: center; } .content{ width: 50%; flex-direction: column; align-items: center; justify-content: center; } .text1{ width: 100%; height: 200px; border:1px solid #1a1919; margin-bottom: 50px; text-align: center; word-break: break-word; font-size: 40px; } .text2{ width: 100%; height: 200px; border:1px solid #0931e8; text-align: center; word-break: break-all; font-size: 40px; } ``` ​ ![zh-cn_image_0000001209033195](figures/zh-cn_image_0000001209033195.png) - text组件支持[Span](../reference/arkui-js/js-components-basic-span.md)子组件 ```html
This is a passage This 1 is a 1 passage
``` ![zh-cn_image_0000001163372568](figures/zh-cn_image_0000001163372568.png) > **说明:** > - 当使用Span子组件组成文本段落时,如果Span属性样式异常(例如:font-weight设置为1000),将导致文本段落显示异常。 > > - 在使用Span子组件时,注意text组件内不能存在文本内容,如果存在文本内容也只会显示子组件Span里的内容。 ## 场景示例 text组件通过数据绑定展示文本内容,Span组件通过设置show属性来实现文本内容的隐藏和显示。 ```html
{{ content }}
{{ content }} 1 Hide clip
``` ```css /* xxx.css */ .container { width: 100%; height: 100%; align-items: center; flex-direction: column; justify-content: center; background-color: #F1F3F5; } .title { font-size: 26px; text-align:center; width: 200px; height: 200px; } ``` ```js // xxx.js export default { data: { isShow:true, content: 'Hello World' }, onInit(){ }, test(e) { this.isShow = e.checked } } ``` ![zh-cn_image_0000001208636379](figures/zh-cn_image_0000001208636379.gif) ## 相关实例 针对text开发,有以下相关实例可供参考: - [`JsComponentCollection`:JS组件集合(JS)(API9)](https://gitee.com/openharmony/applications_app_samples/tree/OpenHarmony-3.2-Release/code/UI/JsComponentClollection/JsComponentCollection)