小程序-添加粘性布局

复制代码
// 获取元素位置
const getElementPosition = () => {
    const query = uni.createSelectorQuery()
    
    // 获取顶部栏高度
    query.select('.anchor-title').boundingClientRect()
    // 获取筛选区域位置和高度
    query.select('.filter-section').boundingClientRect()
    
    query.exec(res => {
        // 计算顶部栏高度(包括状态栏和搜索框)
        if (res[0]) {
            topBarHeight.value = res[0].top + 80 // 加上一些边距
        }
        
        // 获取筛选区域的位置
        if (res[1]) {
            filterTop.value = res[1].top
            filterHeight.value = res[1].height
        }
    })
}

// 滚动处理
const handleScroll = (e: any) => {
    const scrollTop = e.detail.scrollTop
    
    // 判断是否吸顶
    if (filterTop.value > 0) {
        const shouldFix = scrollTop >= filterTop.value - topBarHeight.value
        if (isFilterFixed.value !== shouldFix) {
            isFilterFixed.value = shouldFix
        }
    }
}
  1. 添加元素占位,

2.添加粘性布局

  1. 筛选栏滑动到一定位置后, 变成吸顶的筛选栏,
  1. 在筛选框位置添加占位,

  2. 写一个单独的定位筛选栏, 页面滚动到一定位置后,展示这个单独的定位栏

相关推荐
zithern_juejin几秒前
Date/RegExp/Error/ArrayBuffer
javascript
zenRRan13 分钟前
Karpathy公开附议:AI Agent 的输出格式,正在从 Markdown 走向 HTML
前端·html
燐妤22 分钟前
前端HTML编程5:JavaScript完全指南
前端·javascript·html
八月欢喜25 分钟前
【Facebook】 实时消息监控难点解析
javascript·python·facebook
3D探路人29 分钟前
模灵 大模型聚合API 转发流程技术实现
java·大数据·开发语言·前端·人工智能·计算机视觉
烛阴1 小时前
Unity资源加载进化论:从AssetBundle到Addressables,一文带你吃透手游资源管理
前端·c#·unity3d
l1t1 小时前
JIT执行python脚本的工具codon安装和测试
开发语言·python
TO_WebNow1 小时前
使用thinkPHP8.x 访问接口提示跨域
前端·php
掘金一周1 小时前
回家的时候用车,不回家感觉又没啥用,这车还要不要买 | 沸点周刊 5.14
前端
zithern_juejin1 小时前
Map/Set/WeakMap/WeakSet
javascript