字符

定义字符(chars)是否以及如何被分割。
分割后的字符元素可以通过 TextSplit 实例的 chars 属性返回的数组来访问。

const { chars } = splitText(target, { chars: true });

默认分割包装器

默认情况下,每个字符都会被包裹在一个带有以下样式和数据属性的 span 元素中

<span style="display: inline-block;" data-line="0" data-word="0" data-char="0">H</span>
<span style="display: inline-block;" data-line="0" data-word="0" data-char="1">E</span>
<span style="display: inline-block;" data-line="0" data-word="0" data-char="2">Y</span>

自定义分割包装器

分割包装器可以通过传递一个 分割参数Object 对象,或者传递一个自定义的 HTML 模板 String 字符串进行配置。

当同时按行分割时,字符(chars)的动画处理

每次行分割都会覆盖现有的字符元素,这会导致正在运行的字符动画在字体加载完毕或文本元素每次调整大小时停止。
split.addEffect() 方法中声明动画可以确保在调整大小之间连续播放,并在使用 split.revert() 时自动恢复动画。

const split = splitText(target, params);

split.addEffect(({ lines, words, chars }) => animate([lines, words, chars], {
  opacity: { from: 0 },
}));

split.revert(); // This also reverts the animation declared with addEffect

接受

  • 布尔值
  • 分割参数 的 Object 对象
  • HTML 模板 String 字符串

默认值

false

chars 代码示例

import { animate, splitText, stagger } from 'animejs';

const { chars } = splitText('p', {
  chars: { wrap: 'clip' },
});

animate(chars, {
  y: [
    { to: ['100%', '0%'] },
    { to: '-100%', delay: 750, ease: 'in(3)' }
  ],
  duration: 750,
  ease: 'out(3)',
  delay: stagger(50),
  loop: true,
});
<div class="large centered row">
  <p class="text-xl">Split text by chars.<br>文字ごとに分割します。</p>
</div>
<div class="small row"></div>