极乐门资源网 Design By www.ioogu.com
本文实例为大家分享了微信小程序实现锚点跳转的具体代码,供大家参考,具体内容如下
1、先上效果图,看看是不是你想要的。
2、主要用到的微信小程序的scroll-view 组件实现该效果。核心主要是使用scroll-into-view属性跳转对应的标签页和标签内容区域和bindscroll事件监听标签内容区域距离页面顶部的距离来判断顶部的标签应该处于哪个标签。
3、wxml代码:
<!-- start 标签区域 --> <view class="text" style="height:{{height}}px " > <!-- scroll-into-view 可以跳转到绑定值对应的ID的标签区域 --> <scroll-view class='scroll-x-view1' scroll-x='true' scroll-into-view='{{indexMaodian}}'> <view bindtap="toDetail" data-id="a1" class='scroll-view-item1 bg_red' id="a" >1标签</view> <view bindtap="toDetail" data-id="b1" class='scroll-view-item1 bg_blue' id="b">2标签</view> <view bindtap="toDetail" data-id="c1" class='scroll-view-item1 bg_green' id="c">3标签</view> <view bindtap="toDetail" data-id="d1" class='scroll-view-item1 bg_yellow' id="d">4标签</view> <view bindtap="toDetail" data-id="e1" class='scroll-view-item1 bg_red' id="e">5标签</view> </scroll-view> <!-- end 标签区域 --> <!-- start 标签对应内容区域 --> <scroll-view class='scroll-x-view' scroll-y='true' bindscroll="onPageScroll" scroll-into-view='{{storeDetail}}'> <view class='scroll-view-item bg_red' id="a1">1标签对应内容区域</view> <view class='scroll-view-item bg_blue' id="b1">2标签对应内容区域</view> <view class='scroll-view-item bg_green' id="c1">3标签对应内容区域</view> <view class='scroll-view-item bg_yellow' id="d1">4标签对应内容区域</view> <view class='scroll-view-item bg_red' id="e1">5标签对应内容区域</view> </scroll-view> <!-- end 标签对应内容区域 --> </view>
4、wxss代码:
.text{ width: 100%; display: flex; flex-direction: column; } .scroll-x-view { width: 100%; display: flex; flex: 1; } .scroll-x-view .scroll-view-item { margin-top: 50rpx; width: 750rpx; height: 800rpx; display:inline-block; } .bg_red { background: lightpink; } .bg_blue { background: lightblue; } .bg_green { background: lightgreen; } .bg_yellow { background: lightyellow; } .scroll-x-view1 { width: 100%; height: 100rpx; white-space: nowrap; } .scroll-x-view1 .scroll-view-item1 { width: 400rpx; height: 100rpx; display:inline-block; }
5、js代码:
Page({ /** * 页面的初始数据 */ data: { // 标签锚点跳转值 indexMaodian: 'a', // 标签详情内容锚点跳转 storeDetail: 'a1' }, // 监听页面滑动距离 onPageScroll(e) { // 通过滑动的距离判断页面滑动那个区域让后让顶部的标签栏切换到对应位置 var height = Number(e.detail.scrollTop) if (height <= 400) { // 滑到1区域 this.setData({ indexMaodian: 'a' }); } else if (height > 400 && height<= 800) { // 滑到2区域 this.setData({ indexMaodian: 'b' }); } else if (height > 800 && height <= 1200) { // 滑到3区域 this.setData({ indexMaodian: 'c' }); } else if (height > 1200 && height <= 1600) { // 滑到4区域 后面难得写了,以此类推即可 this.setData({ indexMaodian: 'd' }); } }, // 跳转到对应的标签详情内容区 toDetail(e) { let id = e.target.dataset.id this.setData({ storeDetail: id }) }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { var systemInfo = wx.getSystemInfoSync(); var windowHeight = systemInfo.windowHeight; // 拿到导航栏以下可视区域的高度 this.setData({ height: windowHeight }); }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { }, /** * 生命周期函数--监听页面显示 */ onShow: function () { }, /** * 生命周期函数--监听页面隐藏 */ onHide: function () { }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { }, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { } })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
微信小程序,锚点跳转
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无微信小程序实现锚点跳转的评论...
更新日志
2024年11月15日
2024年11月15日
- 谭咏麟《20世纪中华歌坛名人百集珍藏版》[WAV+CUE][1G]
- 炉石传说40轮盘术最新卡组代码在哪找 标准40轮盘术卡组代码分享
- 炉石传说亲王贼怎么玩 2024亲王贼最新卡组代码分享
- 炉石传说30.6.2补丁后有什么卡组 30.6.2最强卡组最新推荐
- 模拟之声慢刻CD《蔡琴名曲回顾遇听》[原抓WAV+CUE]
- BruceLiu-WAVES(MusicbySatie)(2024)2CD[24Bit-96kHz]FLAC
- KonstantinKrimmel-MythosSchubertLoewe(2024)[24Bit-96kHz]FLAC
- 2024雷蛇高校挑战赛 嘤式分解助力收官之战
- 海信发布110吋世俱杯官方定制AI电视 引领智能观赛
- 海信发布27英寸显示器大圣G5 Pro:采用自研超解析芯片、友达原厂模组
- 蔡琴《机遇》1:1母盘直刻日本头版[WAV分轨][1.1G]
- 陈百强《与你几分钟的约会》XRCD+SHMCD限量编号版[低速原抓WAV+CUE][994M]
- 陈洁丽《监听王NO.1 》示范级发烧天碟[WAV+分轨][1.1G]
- 单色凌.2014-小岁月太着急【海蝶】【WAV+CUE】
- 陈淑桦.1988-抱紧我HOLD.ME.NOW【EMI百代】【WAV+CUE】