Skip to content

Text

绘制文本。与 HTML5 文本显示效果基本一致。


继承

Text  >  UI

关键属性

width?: number

文本框宽度,不设置时为自动宽度。

height?: number

文本框高度,不设置时为自动高度。

text: string | number

文本内容。

样式属性

fontFamily: string

字体, 同 css,多个字体用逗号隔开。

fontSize: number

文字大小。

fontWeight: IFontWeightNumer | IFontWeightString

文字粗细。

ts
type IFontWeightNumer = 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900

type IFontWeightString =
  | 'thin' // 100
  | 'extra-light' // 200
  | 'light' // 300
  | 'normal' // 400
  | 'medium' // 500
  | 'semi-bold' // 600
  | 'bold' // 700
  | 'extra-bold' // 800
  | 'black' // 900

italic: boolean

文字是否倾斜。

textCase: ITextCase

文字大小写格式。

ts
type ITextCase =
  | 'title' // 单词首字母大写
  | 'upper' // 全部大写
  | 'lower' // 全部小写
  | 'none'

textDecoration: ITextDecoration

文字下划线或删除线。

ts
type ITextDecoration =
  | 'under' // 下划线
  | 'delete' // 删除线
  | 'none'

letterSpacing: number | IUnitData

字间距,可使用百分比类型, 默认为 0。

ts
interface IUnitData {
  type: 'percent''px'
  value: number
}

text.letterSpacing = {
  type: 'percent',
  value: 0.5, // 50%
}

lineHeight: numberIUnitData

行间距,可使用百分比类型, 默认行高为 150%。

ts
text.lineHeight = {
  type: 'percent',
  value: 1.5, // 150%
}

textWrap: ITextWrap

文本换行规则, 默认为 normal。

ts
type ITextWrap =
'normal'  // 在允许的换行点自动换行,不断开word
| 'none'  // 强制不换行
| 'break' // 可断开word换行,类似 CSS 的 break-all

textOverflow: IOverflowstring

如何显示超出固定宽高的文本, 可自定义省略文本。

ts
type IOverflow = 'show' | 'hide'

// 自定义省略文本

text.textOverflow = '...'

段落属性

paraIndent: number

段落首行缩进,单位为 px。

TIP

在 HTML5 中编辑文本时需将\n替换为<p>标签,段落样式在<p>标签上进行设置。

paraSpacing: number

段落间距,单位为 px。

textAlign: ITextAlign

文本对齐方式,可以设置 'both' 来强制两端对齐文本。

ts
type ITextAlign =
  | 'left' // 左对齐
  | 'center' // 居中对齐
  | 'right' // 右对齐
  | 'justify' // 两端对齐段落
  | 'both' // 强制两端对齐文本,补充 justify 的不足

verticalAlign: IVerticalAlign

文本垂直对齐。

ts
type IVerticalAlign =
  | 'top' // 顶部对齐
  | 'middle' // 垂直居中对齐
  | 'bottom' // 底部对齐

autoSizeAlign: boolean

当文本没有宽高且有对齐属性时,是否对齐起点坐标,默认为 true。

如希望文本位置从起点坐标开始,可设为 false。

padding: number | number[]

文本内边距,可分别设置 4 个值。

ts
padding: [20, 10, 20, 10] // [top, right, bottom, left]
padding: [20, 10, 20] // [top, (right-left), bottom]
padding: [20, 10] // [ (top-bottom), (right-left)]
padding: 20 // all

编辑属性

resizeFontSize: boolean

自动宽高的文本是否通过修改字体大小进行 resize, 默认为 false。

示例

创建文本

ts
import { Leafer, Text } from 'leafer-ui'

const leafer = new Leafer({ view: window })

const text = new Text({
    fill: 'rgb(50,205,121)',
    text: 'Welcome to LeaferJS',
})

leafer.add(text)

创建自适应背景的文本

Box 不设置宽高时,支持自适应内容。

ts
import { Leafer, Box } from 'leafer-ui'

const leafer = new Leafer({ view: window, fill: 'gray' })

const box = new Box({
    x: 100,
    y: 100,
    fill: '#FF4B4B',
    cornerRadius: 20,
    children: [{
        tag: 'Text',
        text: 'Welcome to LeaferJS',
        fill: 'black',
        padding: [10, 20],
        textAlign: 'left',
        verticalAlign: 'top'
    }]
})

leafer.add(box)

文本 count 动画

text 属性传入数字,可支持 count 动画,示例中的文本将从 0 到 100 动态变化。

ts
import { Leafer, Text } from 'leafer-ui'
import '@leafer-in/animate'

const leafer = new Leafer({ view: window })

const text = new Text({
    fill: 'rgb(50,205,121)',
    text: 0,
    animation: {
        style: { text: 100 },
        duration: 2
    }
})

leafer.add(text)

打字机动画

ts
import { Leafer, Text } from 'leafer-ui'
import '@leafer-in/animate'

const leafer = new Leafer({ view: window })

const text = new Text({
    fill: 'rgb(50,205,121)',
    animation: {
        style: { text: 'Welcome to LeaferJS' },
        duration: 2,
    }
})

leafer.add(text)

删除文字动画

ts
import { Leafer, Text } from 'leafer-ui'
import '@leafer-in/animate'

const leafer = new Leafer({ view: window })

const text = new Text({
    fill: 'rgb(50,205,121)',
    text: 'Welcome to LeaferJS',
    animation: {
        style: { text: '' },
        duration: 2,
    }
})

leafer.add(text)

Released under the MIT License.