小程序-添加粘性布局

复制代码
// 获取元素位置
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. 写一个单独的定位筛选栏, 页面滚动到一定位置后,展示这个单独的定位栏

相关推荐
竹林8184 分钟前
Solana前端开发:我在一个NFT铸造页面上被@solana/web3.js的Connection和Transaction签名坑了两天
前端
冬奇Lab23 分钟前
每日一个开源项目(第144篇):ai-website-cloner-template - 一条命令、多 Agent 并行,把任意网站逆向成 Next.js 代码
前端·人工智能·开源
玄玄子37 分钟前
webpack publicPath作用原理
前端·webpack·程序员
HduSy37 分钟前
帮 Claude Code 做了个菜单栏 Token 看板,聊聊里面的一些实现逻辑
前端
minglie39 分钟前
一个置换问题
javascript
用户0595401744641 分钟前
用了6个月LangChain,才发现AI Agent的记忆存储一直有坑——写了23个Pytest用例才彻底修好
前端·css
奶油mm1 小时前
我偷偷把公司的祖传 jQuery 项目改成了 Vue3,CTO 没发现,但全组都来抄我的代码了
前端
用户2136610035721 小时前
Vue2非父子通信与动态组件
前端·vue.js
默_笙1 小时前
🌀 别再手动写 Prompt 了!我让 AI 自己循环改到满意为止
javascript
PedroQue991 小时前
Vite插件体系1.0.0:API稳定,生产就绪
前端·vite