微信小程序?qū)崿F(xiàn)頁面浮動導航
更新時間:2020年01月08日 16:05:27 作者:代碼養(yǎng)家
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)頁面浮動導航,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
一、前言
做復雜的小程序就與web頁面的區(qū)別原來越小了,一些web頁面的功能會被要求添加到微信小程序頁面中。
二、功能
頁面在滑動的時候頂部頁面導航跟隨滑動,當點擊導航中的任意一項時返回頁面頂部。
三、實現(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 { /*導航樣式*/
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); //加載數(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é):
這個功能的實現(xiàn)主要是通過onPageScroll頁面注冊函數(shù)來實現(xiàn)頁面滾動,通過pageScrollTo api實現(xiàn)導航選項在被選中時返回到頁面頂部。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用JavaScript實現(xiàn)計算顏色的相對亮度并確定相應(yīng)的文本顏色
這篇文章主要為大家詳細介紹了如何使用JavaScript實現(xiàn)計算顏色的相對亮度并確定相應(yīng)的文本顏色,感興趣的小伙伴可以跟隨小編一起學習一下2024-04-04
純前端JavaScript實現(xiàn)Excel IO案例分享
這篇文章主要為大家詳細介紹了純前端JavaScript實現(xiàn)Excel IO案例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-08-08

