微信小程序?qū)崿F(xiàn)頁(yè)面浮動(dòng)導(dǎo)航
一、前言
做復(fù)雜的小程序就與web頁(yè)面的區(qū)別原來(lái)越小了,一些web頁(yè)面的功能會(huì)被要求添加到微信小程序頁(yè)面中。
二、功能
頁(yè)面在滑動(dòng)的時(shí)候頂部頁(yè)面導(dǎo)航跟隨滑動(dòng),當(dāng)點(diǎn)擊導(dǎo)航中的任意一項(xiàng)時(shí)返回頁(yè)面頂部。
三、實(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)航浮動(dòng)起來(lái)的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)航欄浮動(dòng) } 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){ //開始滾動(dòng) if (!this.data.pageVariable.isFloat){ this.setData({ 'pageVariable.isFloat':true }); } }else{ this.setData({ 'pageVariable.isFloat': false }); } } })
總結(jié):
這個(gè)功能的實(shí)現(xiàn)主要是通過(guò)onPageScroll頁(yè)面注冊(cè)函數(shù)來(lái)實(shí)現(xiàn)頁(yè)面滾動(dòng),通過(guò)pageScrollTo api實(shí)現(xiàn)導(dǎo)航選項(xiàng)在被選中時(shí)返回到頁(yè)面頂部。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序仿今日頭條導(dǎo)航欄滾動(dòng)解析
- 微信小程序?qū)隫ant報(bào)錯(cuò)VM292:1 thirdScriptError的解決方法
- 微信小程序用戶授權(quán)彈窗 拒絕時(shí)引導(dǎo)用戶重新授權(quán)實(shí)現(xiàn)
- 微信小程序?qū)崿F(xiàn)的動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題功能示例
- 微信小程序頂部導(dǎo)航欄滑動(dòng)tab效果
- 微信小程序 配置頂部導(dǎo)航條標(biāo)題顏色的實(shí)現(xiàn)方法
- 微信小程序教程系列之設(shè)置標(biāo)題欄和導(dǎo)航欄(7)
- 微信小程序 導(dǎo)入圖標(biāo)實(shí)現(xiàn)過(guò)程詳解
相關(guān)文章
JS+HTML5 FileReader實(shí)現(xiàn)文件上傳前本地預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了JS+HTML5 FileReader實(shí)現(xiàn)文件上傳前本地預(yù)覽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07掃微信小程序碼實(shí)現(xiàn)網(wǎng)站登陸實(shí)現(xiàn)解析
這篇文章主要介紹了掃微信小程序碼實(shí)現(xiàn)網(wǎng)站登陸實(shí)現(xiàn)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08uniapp中的picker選擇器的幾種使用場(chǎng)景
本文主要介紹了uniapp中的picker選擇器的幾種使用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Bootstrap框架結(jié)合jQuery仿百度換膚功能實(shí)例解析
這篇文章主要為大家詳細(xì)介紹了Bootstrap框架結(jié)合jQuery仿百度換膚功能實(shí)現(xiàn)代碼解析,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09js實(shí)現(xiàn)mp3錄音通過(guò)websocket實(shí)時(shí)傳送+簡(jiǎn)易波形圖效果
這篇文章主要介紹了js實(shí)現(xiàn)mp3錄音通過(guò)websocket實(shí)時(shí)傳送+簡(jiǎn)易波形圖效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì)對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06通過(guò)JS自動(dòng)隱藏手機(jī)瀏覽器的地址欄實(shí)現(xiàn)原理與代碼
大家通過(guò)手機(jī)自帶瀏覽器打開百度、淘寶,在首頁(yè)加載完畢后,會(huì)自動(dòng)隱藏頁(yè)面上方的地址欄,感興趣的朋友可以參考下2013-01-01js左右彈性滾動(dòng)對(duì)聯(lián)廣告代碼分享
這個(gè)對(duì)聯(lián)廣告與其它的有所區(qū)別,這個(gè)是頁(yè)面加載時(shí)先沒(méi)看到廣告,然后從左邊快速飛進(jìn)來(lái)的兩個(gè)對(duì)聯(lián)廣告哦,下面我們一起來(lái)看看對(duì)聯(lián)廣告效果代碼2014-02-02