跳到主要内容

粘性布局 Sticky

Sticky 组件与 CSS 中 position: sticky 属性实现的效果一致。可切换 css 模式和 js 模式,纯 css 模式不适用的情况可以采用 js 模式, js 模式采用 IntersectionObserver Api。

用法示例

基础用法

<ti-sticky>
<div>吸顶元素</div>
</ti-sticky>

使用css模式

使用条件:
  1. 父元素不能overflow:hidden或者overflow:auto属性;
  2. 父元素的高度需大于sticky元素的高度;
  3. sticky元素仅在其父元素内生效。
<ti-sticky use-pure-css>
<div>吸顶元素</div>
</ti-sticky>

吸顶距离

<ti-sticky offset-top="100">
<div>吸顶元素</div>
</ti-sticky>

指定容器

use-pure-css模式下无需指定container,默认在父元素内生效。

code
<div id="container" style="height:250px;">
<ti-sticky id="ti-sticky">
<ti-button>指定容器</ti-button>
</ti-sticky>
</div>

ti-sticky API

属性 Properties

名称类型必填默认值说明备注
offset-topnumber0吸顶时与顶部的距离,单位 px-
containerfunction-一个函数,返回容器对应的 NodesRef 节点-
disabledbooleanfalse是否禁止吸顶-
z-indexnumber99z-index-
use-pure-cssbooleanfalse使用css的position: sticky实现-

事件 Events

名称参数列表描述备注
fixed(e: CustomEvent<{isFixed: boolean}>) => void 在吸顶状态改变是触发-

插槽 Slots

名称说明备注
default默认插槽-