微信小程序?qū)崿F(xiàn)頁面浮動導(dǎo)航
一、前言
做復(fù)雜的小程序就與web頁面的區(qū)別原來越小了,一些web頁面的功能會被要求添加到微信小程序頁面中。
二、功能
頁面在滑動的時候頂部頁面導(dǎo)航跟隨滑動,當(dāng)點(diǎn)擊導(dǎo)航中的任意一項(xiàng)時返回頁面頂部。
三、實(shí)現(xiàn)
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 { /*導(dǎo)航樣式*/ 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 { /*導(dǎo)航浮動起來的css*/ position: fixed; top: 0; z-index: 1000; } .navigation-item-selected { /*導(dǎo)航項(xiàng)選中的樣式*/ color: #40a0ee; height: 80rpx; line-height: 80rpx; border-bottom: 3rpx solid #40a0ee; }
js代碼:
Page({ data:function () { var model = {}; model.pageVariable = { curSelectedItemId:'0', //頂部導(dǎo)航欄,當(dāng)前選中的項(xiàng) isFloat:false, //控制導(dǎo)航欄浮動 } return model; }(), /** * 選擇導(dǎo)航 */ selectNavigationItem:function(e){ this.setData({ 'pageVariable.curSelectedItemId': e.currentTarget.dataset.id, 'pageVariable.isFloat':false }); wx.pageScrollTo({ scrollTop: 0, }); this.initData(e.currentTarget.dataset.id); //加載數(shù)據(jù) }, onPageScroll:function(res){ if (res.scrollTop >= 1){ //開始滾動 if (!this.data.pageVariable.isFloat){ this.setData({ 'pageVariable.isFloat':true }); } }else{ this.setData({ 'pageVariable.isFloat': false }); } } })
總結(jié):
這個功能的實(shí)現(xiàn)主要是通過onPageScroll頁面注冊函數(shù)來實(shí)現(xiàn)頁面滾動,通過pageScrollTo api實(shí)現(xiàn)導(dǎo)航選項(xiàng)在被選中時返回到頁面頂部。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序 (三)tabBar底部導(dǎo)航詳細(xì)介紹
- 微信小程序 配置頂部導(dǎo)航條標(biāo)題顏色的實(shí)現(xiàn)方法
- 微信小程序中進(jìn)行地圖導(dǎo)航功能的實(shí)現(xiàn)方法
- 微信小程序教程系列之設(shè)置標(biāo)題欄和導(dǎo)航欄(7)
- 微信小程序 開發(fā)之頂部導(dǎo)航欄實(shí)例代碼
- 微信小程序頂部可滾動導(dǎo)航效果
- 微信小程序中頂部導(dǎo)航欄的實(shí)現(xiàn)代碼
- 詳解微信小程序設(shè)置底部導(dǎo)航欄目方法
- 微信小程序 wxapp導(dǎo)航 navigator詳解
- 微信小程序自定義導(dǎo)航隱藏和顯示功能
相關(guān)文章
使用JavaScript實(shí)現(xiàn)計(jì)算顏色的相對亮度并確定相應(yīng)的文本顏色
這篇文章主要為大家詳細(xì)介紹了如何使用JavaScript實(shí)現(xiàn)計(jì)算顏色的相對亮度并確定相應(yīng)的文本顏色,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04js實(shí)現(xiàn)城市級聯(lián)菜單的2種方法
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)城市級聯(lián)菜單的2種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06純前端JavaScript實(shí)現(xiàn)Excel IO案例分享
這篇文章主要為大家詳細(xì)介紹了純前端JavaScript實(shí)現(xiàn)Excel IO案例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-08-08