微信小程序?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í)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序 (三)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òng)導(dǎo)航效果
- 微信小程序中頂部導(dǎo)航欄的實(shí)現(xiàn)代碼
- 詳解微信小程序設(shè)置底部導(dǎo)航欄目方法
- 微信小程序 wxapp導(dǎo)航 navigator詳解
- 微信小程序自定義導(dǎo)航隱藏和顯示功能
相關(guān)文章
Javascript對(duì)象中關(guān)于setTimeout和setInterval的this介紹
Javascript對(duì)象中關(guān)于setTimeout和setInterval的this介紹,需要的朋友可以參考下2012-07-07
javascript htmlencode函數(shù)(ff兼容版) 主要是編輯器中反轉(zhuǎn)html代碼
前端實(shí)現(xiàn)下載文件(包含壓縮包下載)方式詳細(xì)總結(jié)
JavaScript實(shí)現(xiàn)背景圖像切換3D動(dòng)畫效果示例詳解
微信小程序用戶授權(quán)彈窗 拒絕時(shí)引導(dǎo)用戶重新授權(quán)實(shí)現(xiàn)
js form 驗(yàn)證函數(shù) 當(dāng)前比較流行的錯(cuò)誤提示
javascript實(shí)現(xiàn)攝像頭拍照預(yù)覽

