uniapp+vue3 微信小程序中 页面切换tab 页面滚动到指定锚点位置,滚动页面时候到达指定锚点位置吸顶tab 会自动进行切换

uniapp+vue3 微信小程序中 页面切换tab 页面滚动到指定锚点位置,滚动页面时候到达指定锚点位置吸顶tab 会自动进行切换

页面布局如下:

javascript 复制代码
<view class="tabs-box" v-if="showTabs">
	<view class="tabs-cell" :class="[tabsActive==index?'active':'']" @click="tabsFun(index)"
	v-for="(item,index) in tabsList" :key="index">{{item.name}}</view>
</view>
<view class="tabs0"> 。。。。。</view>
<view class="tabs1"> 。。。。。</view>
<view class="tabs2"> 。。。。。</view>

<script setup>
import { reactive, ref ,nextTick, } from 'vue';
let targetId = ref(null)//锚点id
let showTabs = ref(false)//是否显示tabs
let tabsActive = ref(0)//默认tabs选择
let tabsList = ref([{name:'商品',h:0},{name:'评价',h:0},{name:'详情',h:0}])
//切换tab 方法
function tabsFun(e){
	tabsActive.value = e
	//切换tab 滚动到对应锚点位置
	const query = uni.createSelectorQuery();
	query.select(`#tabs${e}`).boundingClientRect();
	query.selectViewport().scrollOffset();
	query.exec(res => {
	  if (res[0] && res[1]) {
	    const { top } = res[0];
	    const { scrollTop } = res[1];
		// console.log(scrollTop+top)
	    uni.pageScrollTo({
	      scrollTop: scrollTop + top - 120,//120 为实际顶部tab的高度
	      duration: 300 // 滚动持续时间,单位为ms
	    });
	  }
	});
}
//下面是滚动页面 切换顶部tab的方法
import { onPageScroll} from "@dcloudio/uni-app"
//首先 获取每个锚点元素距离顶部的高度距离
nextTick(()=>{
	tabsList.value.map((item,index)=>{
		const query = wx.createSelectorQuery()
		query.select(`#tabs${index}`).boundingClientRect(rect => {
			if (rect) { 
			//获取元素距离顶部的高度有时会忽略padding或margin的高度  这里适度加上一些高度即可  
			//如果中间有循环列表高度 需要加上 length*height 高度的距离 否则滚动不准确 如果列表为5 margin为20
				tabsList.value[index].h = rect.top + (20 * 5) 
			}
		}).exec();
	})
})
// onPageScroll 方法来更新 scrollTop 的值
onPageScroll((e) => {
	// tabs切换判断
	tabsList.value.map((item,index)=>{
		//如果第一个tab高度为0  可以自己判断
		if((e.scrollTop + 120) > item.h){ //120 为实际顶部tab的高度
			tabsActive.value = index
		}
	})
	// 是否显示吸顶tabs按钮
	if(e.scrollTop > 200){
		showTabs.value = true
	}else{
		showTabs.value = false
		tabsActive.value = 0
	}
})

</script>

注意 onPageScroll 方法 如果不生效 查找代码中是否有如下问题

1,页面最外层盒子容器 是否设置了 overflow-y: auto; overflow: hidden; 设置了就删除 否则滚动不生效,

2,pages.json 中指定页面 "disableScroll": false 必须设置为 false

3,如果是自定义导航栏 需要设置 "navigationStyle": "custom",

javascript 复制代码
 {
	"path" : "pages/goods/goodsInfo",//商品详情
	"style" : {
		"navigationStyle": "custom", 
		"disableScroll": false 
	}
}
相关推荐
2501_916007472 小时前
没有 Mac,如何在 Windows 上架 iOS 应用?一套可落地的工程方案
android·macos·ios·小程序·uni-app·iphone·webview
不想吃菠萝2 小时前
pc端微信小程序post传递data是字符串,自动加了双引号问题修改方案
微信小程序·小程序
宠友信息2 小时前
打造可持续增长的垂直社区:仿小红书平台功能体系与架构深度解析
java·微服务·微信小程序·springboot·uniapp
2501_915106322 小时前
uni-app 上架 iOS 的完整实践,从跨端开发到稳定提交的工程路径
android·ios·小程序·uni-app·cocoa·iphone·webview
2501_916007474 小时前
HTTPS工作原理与重要性:全面安全指南
网络协议·安全·ios·小程序·https·uni-app·iphone
一点晖光17 小时前
微信小程序输入框光标从中间删除跳到最后bug解决
微信小程序·uniapp·ios光标
济南壹软网络科技有限公司17 小时前
国际盲盒电商新范式:深度剖析 V4 系统的全球化云原生架构
uni-app·盲盒源码·国际盲盒源码·盲盒开源源码·多语言盲盒源码
小皮虾17 小时前
护航隐私!小程序纯前端“证件加水印”:OffscreenCanvas 全屏平铺实战
前端·javascript·微信小程序
白宇横流学长18 小时前
基于SpringBoot医院复查开药网站和微信小程序的设计
spring boot·后端·微信小程序