.Element
ZRender 的 Element 元素类。
状态
一系列与元素实例状态管理相关的 APIs。
示例:
// * 为元素实例添加一个鼠标的 hover 效果
// 为元素注册一个 hover 状态对象
el.states.hover = {
  style: {
    fill: 'red',
  },
};
// 设置元素的状态转换动画
el.stateTransition = {
  duration: 400,
  done: () => {
    console.log('switch state done!');
  },
};
// 添加鼠标事件
el.onmouseover = function () {
  el.useState('hover', true);
};
el.onmouseover = function () {
  el.removeState('hover');
};
states
states: Dictionary<ElementState> = {}
元素实例的状态集合(状态是一个元素实例的属性集合)。
stateProxy
stateProxy?: (stateName: string, targetStates?: string[]) => ElementState
元素实例的状态代理,可以通过状态名称动态生成状态对象。ZRender 首先会尝试通过 stateProxy() 获取元素的状态对象,其次  才会访问 states。
stateTransition
stateTransition: ElementAnimateConfig
元素实例的状态转换动画配置。
currentStates
currentStates?: string[] = []
元素实例当前已经应用的状态名称列表。
ensureState()
ensureState(name: string): ElementState
确保状态对象存在(不存在就创建一个空的状态对象)。
参数
| 名称 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| name | string | 状态名称 | 
返回值
| 名称 | 类型 | 描述 | 
|---|---|---|
| state | ElementState | 参数 name对应的状态对象 | 
getState()
getState(name: string)
获取指定的状态对象定义。
hasState()
hasState()
判断元素当前状态是否不为空。
useState()
useState(stateName: string, keepCurrentStates?: boolean, noAnimation?: boolean, forceUseHoverLayer?: boolean): ElementState
使用状态。
参数
| 名称 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| stateName | string | 状态名称 | |
| keepCurrentStates | boolean | false | 是否需要保持当前已应用的状态 | 
| noAnimation | boolean | false | 不需要动画过渡 | 
| forceUseHoverLayer | boolean | false | 
返回值
| 名称 | 类型 | 描述 | 
|---|---|---|
| state | ElementState | 参数 stateName对应的状态对象 | 
useStates()
useStates(states: string[], noAnimation?: boolean, forceUseHoverLayer?: boolean)
使用多个状态。
参数
| 名称 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| states | string[] | 状态名称列表 | |
| noAnimation | boolean | false | 不需要动画过渡 | 
| forceUseHoverLayer | boolean | false | 
removeState()
removeState(state: string)
移除状态。
参数
| 名称 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| state | string | 状态名称 | 
clearStates()
clearStates(noAnimation?: boolean)
清空所有状态。
参数
| 名称 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| noAnimation | boolean | false | 不需要动画过渡 | 
动画
animate()
animate(key?: string, loop?: boolean, allowDiscreteAnimation?: boolean)
为元素设置动画。
相关
animateTo()
animateTo(target: Props, cfg?: ElementAnimateConfig, animationProps?: MapToType<Props, boolean>)
将元素过渡到目标状态。
animateFrom()
animateFrom(target: Props, cfg: ElementAnimateConfig, animationProps?: MapToType<Props, boolean>)
将元素从目标状态过渡到当前状态。
stopAnimation()
stopAnimation(scope?: string, forwardToLast?: boolean)
停止动画。