您好,登錄后才能下訂單哦!
這篇文章主要介紹微信小程序如何實現頁面浮動導航,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
一、前言
做復雜的小程序就與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 }); } } })
以上是“微信小程序如何實現頁面浮動導航”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。