欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 微信小程序开发--导航跟随

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

微信小程序开发--导航跟随

发布时间:2020-11-12  

最近开发小程序的时候遇到这样一个需求:如图1

微信小程序开发--导航跟随

页面向下滚动到白色导航的位置时,白色导航固定到页面最上方;当页面向上滚动到白色导航时,白色导航恢复到原始位置;点击各个导航,平滑的跳到相应位置。

思路1:

1.给导航设置position: absolute; 页面向下滚动到白色导航的位置时,将给导航设置为position: fixed;

2.绑定小程序滚动事件bindscroll,监听滚动距离;

代码如下:

wxml:

<scroll-view class="layout" bindscroll='layoutScroll' scroll-y="true" > <view class='banner'> <text>我是一个banner</text> </view> <!-- 导航开始 --> <view class='nav clearfix {{navFixed?"positionFixed":""}}'> <view class='nav_row'> <text>导航1</text> </view> <view class='nav_row'> <text>导航2</text> </view> <view class='nav_row'> <text>导航3</text> </view> <view class='nav_row'> <text>导航4</text> </view> </view> <!-- 导航结束 --> <!-- 内容开始 --> <view class='content content1'> <text>我是内容1</text> </view> <view class='content content2'> <text>我是内容2</text> </view> <view class='content content3'> <text>我是内容3</text> </view> <view class='content content4'> <text>我是内容4</text> </view> <!-- 内容结束 --> </scroll-view>

wxss:

.clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } .positionFixed{ position: fixed; left: 0; top: 0; } page{ width: 100%; height:100%; } .layout{ width: 100%; height: 100%; background: #eee; } .banner{ width: 100%; height: 200px; line-height: 200px; background: #FFB11A ; } .banner text{ text-align: center; display: block; } .nav{ width: 100%; height: 45px; line-height: 45px; background: #fff; } .nav_row{ float: left; width: 25%; font-family: PingFangSC-Light; font-size: 16px; color: #333333; } .nav_row text{ text-align: center; display: block; } .content { width: 100%; height: 200px; font-family: PingFangSC-Light; font-size: 16px; color: #333333; padding: 15px; } .content1{ background: #F5BBA4; } .content2{ background: #E9ED9A; } .content3{ background: #9DE59C; } .content4{ background: #98A5E2; }

js:

Page({ data: { scrollTop:'', //滑动的距离 navFixed:false, //导航是否固定 }, //页面滑动 layoutScroll: function (e) { this.data.scrollTop = this.data.scrollTop * 1 + e.detail.deltaY * 1; console.log(this.data.scrollTop) console.log(this.data.navFixed) if (this.data.scrollTop <= -200){ this.setData({ navFixed:true }) }else{ this.setData({ navFixed: false }) } } })

这个代码能基本实现需求,但是存在很大的弊端:

1.导航固定后,页面卡顿一下

2.导航效果延迟较长,用户体验很差

总体来说这种方案并不可取,所以进行第二次迭代

思路2:

未完待续。。。

注意:

1.整个滑动的页面应该写在scroll-view中;