跳到主要内容

粘性布局 Sticky

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

安装使用

import { TiSticky } from '@titian-design/mobile-react'

用法示例

基础用法

const App: React.FC = () => {
return (
<>
<TiSticky>
<div>吸顶元素</div>
</TiSticky>
</>
)
}

使用css模式

使用条件:
  1. 父元素不能overflow:hidden或者overflow:auto属性。
  2. 父元素的高度需大于sticky元素的高度。
  3. sticky元素仅在其父元素内生效
const App: React.FC = () => {
return (
<>
<TiSticky usePureCss>
<div>吸顶元素</div>
</TiSticky>
</>
)
}

吸顶距离

const App: React.FC = () => {
return (
<>
<TiSticky offsetTop={100}>
<div>吸顶元素</div>
</TiSticky>
</>
)
}

指定容器

备注

usePureCss模式下无需指定container,默认在父元素内生效

const App: React.FC = () => {
const ref = useRef(null);
const container = () => ref.current;
return (
<>
<div ref={ref}>
<TiSticky offsetTop={100} container={container}>
<div>吸顶元素</div>
</TiSticky>
...
</div>
</>
)
}

TiSticky API

属性 Properties

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

事件 Events

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

插槽 Slots

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