微信小程序实现页面浮动导航
2019-01-29 12:43
666 查看
一、前言
做复杂的小程序就与web页面的区别原来越小了,一些web页面的功能会被要求添加到微信小程序页面中。
二、功能
页面在滑动的时候顶部页面导航跟随滑动,当点击导航中的任意一项时返回页面顶部。
三、实现
wxml代码:
<view class='container'> <view class='navigation {{pageVariable.isFloat == true ? "float-navigation":""}}'> <view class='{{policyFilter.curSelectNavigationItemFormate(pageVariable.curSelectedItemId,"0")}}' data-id='0' catchtap='selectNavigationItem'>全部</view> <view class='{{policyFilter.curSelectNavigationItemFormate(pageVariable.curSelectedItemId,"1")}}' data-id='1' catchtap='selectNavigationItem'>保障中</view> <view class='{{policyFilter.curSelectNavigationItemFormate(pageVariable.curSelectedItemId,"2")}}' data-id='2' catchtap='selectNavigationItem'>已生效</view> <view class='{{policyFilter.curSelectNavigationItemFormate(pageVariable.curSelectedItemId,"3")}}' data-id='3' catchtap='selectNavigationItem'>未生效</view> </view> </view>
wxss代码:
.navigation { /*导航样式*/ width: 100%; display: flex; justify-content: space-around; align-items: center; height: 80rpx; background-color: #fff; font-size: 28rpx; color: #333; font-weight: 500; box-shadow: inset 0 0 0 0 rgba(0, 0, 0, 0.30); } .float-navigation { /*导航浮动起来的css*/ position: fixed; top: 0; z-index: 1000; } .navigation-item-selected { /*导航项选中的样式*/ color: #40a0ee; height: 80rpx; line-height: 80rpx; border-bottom: 3rpx solid #40a0ee; }
js代码:
Page({ data:function () { var model = {}; model.pageVariable = { curSelectedItemId:'0', //顶部导航栏,当前选中的项 isFloat:false, //控制导航栏浮动 } return model; }(), /** * 选择导航 */ selectNavigationItem:function(e){ this.setData({ 'pageVariable.curSelectedItemId': e.currentTarget.dataset.id, 'pageVariable.isFloat':false }); wx.pageScrollTo({ scrollTop: 0, }); this.initData(e.currentTarget.dataset.id); //加载数据 }, onPageScroll:function(res){ if (res.scrollTop >= 1){ //开始滚动 if (!this.data.pageVariable.isFloat){ this.setData({ 'pageVariable.isFloat':true }); } }else{ this.setData({ 'pageVariable.isFloat': false }); } } })
总结:
这个功能的实现主要是通过onPageScroll页面注册函数来实现页面滚动,通过pageScrollTo api实现导航选项在被选中时返回到页面顶部。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 微信小程序 flex实现导航实例详解
- 如何实现页面右侧浮动导航???点击导航的选项后,页面会定位到指定的栏目模块中
- 微信小程序例子——点击文字实现页面跳转
- 微信小程序 返回上一页面时实现上一页面刷新
- 微信小程序 配置顶部导航条标题颜色的实现方法
- 微信小程序实现页面跳转传值以及获取值的方法分析
- 微信小程序实现嵌入网站H5页面代码
- 微信小程序实现页面加入背景图片以及调节透明度
- 微信小程序模仿分类导航实现多个tab 页
- 微信小程序保存活动页面到本地功能实现
- 微信小程序之页面跳转和参数传递的实现
- 《微信小程序七日谈》- 第四天:页面路径最多五层?导航可以这么玩
- 微信小程序实战(二)---实现搜索页面
- 微信小程序WXML页面上直接进行字符串截取实现方式
- 微信小程序实现页面跳转传值的方法
- 微信小程序例子——点击文字实现页面跳转
- 微信小程序一个页面多个picker实现
- 微信小程序 页面跳转如何实现传值
- 微信小程序 页面跳转传值实现代码
- 微信小程序返回多级页面的实现方法