小程序自定义导航如何实现的,代码是什么
Admin 2022-09-13 群英技术资讯 790 次浏览
今天小编跟大家讲解下有关“小程序自定义导航如何实现的,代码是什么”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。微信小程序自定义导航的具体代码如下
在app.js中获取状态栏信息和胶囊按钮信息
onLaunch() {
// 展示本地存储能力
const logs = wx.getStorageSync('logs') || []
logs.unshift(Date.now())
wx.setStorageSync('logs', logs)
// 获取系统信息
this.globalData.systemInfo = wx.getSystemInfoSync();
// 获取状态栏高度
this.globalData.statusBarHeight = this.globalData.systemInfo.statusBarHeight
// 胶囊按钮位置信息
this.globalData.menuButtonInfo = wx.getMenuButtonBoundingClientRect();
// 获取导航栏高度
this.globalData.navBarHeight = this.globalData.menuButtonInfo.bottom + (this.globalData.menuButtonInfo.top - this.globalData.statusBarHeight)
},
globalData: {
statusBarHeight: '',
menuButtonInfo: {},
navBarHeight:'',
systemInfo:''
},
导航栏高度为胶囊底部位置+(胶囊顶部位置-状态栏高度)
将导航栏封装成组件

navigation-bar.js
properties: {
// 是否显示返回箭头
showBackArrow: {
type: Boolean,
value: true
},
// 是否自定义导航栏标题
customTitle: {
type: Boolean,
value: false
},
// 导航栏标题
title: {
type: String,
value: 'weixin'
},
// 是否自定义返回方法
customBack: {
type: Boolean,
value: false
}
},
data: {
navBarHeight:getApp().globalData.navBarHeight,
statusBarHeight:getApp().globalData.statusBarHeight,
menuButtonInfo:getApp().globalData.menuButtonInfo
},
methods: {
/** 点击返回按钮 */
back() {
if (this.data.customBack) {
this.triggerEvent('back')
} else {
wx.navigateBack({
delta: 0,
})
}
},
/** 点击导航栏标题事件 */
clickTitle(){
this.triggerEvent('clickTitle')
},
}
navigation-bar.wxml
<view class="nav-bar" style="height:{{navBarHeight}}px;">
<view style="height:{{statusBarHeight}}px;"></view>
<view style="height:{{navBarHeight-statusBarHeight}}px;width:{{menuButtonInfo.left}}px;" class="nav-box">
<view class="back-arrow" wx:if="{{showBackArrow}}">
<van-icon name="arrow-left" color="#262626" size="40rpx" bindtap="back"></van-icon>
</view>
<view class="nav-title" style="width: {{showBackArrow?'calc(100% - 40rpx)':'100%'}};">
<text wx:if="{{!customTitle}}" bindtap="clickTitle">{{title}}</text>
<slot wx:if="{{customTitle}}"></slot>
</view>
</view>
</view>
<view style="height:{{navBarHeight}}px;"></view>
navigation-bar.wxss
.nav-bar{
width: 100%;
position: fixed;
top: 0;
left: 0;
background-color: #ffffff;
z-index: 1000000;
}
.nav-box{
padding: 0 20rpx;
display: flex;
align-items: center;
}
.back-arrow{
width: 60rpx;
height: 100%;
display: flex;
align-items: center;
padding-top: 4rpx;
}
.nav-title{
height: 100%;
display: flex;
align-items: center;
font-size: 36rpx;
color: #262626;
font-weight: 600;
}
使用
app.js
"window": {
"navigationStyle": "custom"
},
"usingComponents": {
"navigation-bar":"/components/navigation-bar/navigation-bar",
}
.wxml
<navigation-bar title="打卡" customBack bind:back="backWorkPage"></navigation-bar>

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
关于如何以及为什么要构建多页vue应用,我们在上一篇文章中已经介绍过,感兴趣的请参考构建多页vue应用。本文我们要介绍的是,对于一个多页应用,如何单独打包其中一个(或几个)页面
vue项目如何做主题切换?在项目中,主题切换的需求还是比较常见的,这篇文章就给大家分享一下怎样做一个深色主题和浅色主题切换的效果,本文给大家分享了两种方法,有需要的朋友可以参考。
jquery去掉click事件的方法:1、利用“$(指定元素)”语句获取已经绑定click点击事件的指定元素对象;2、利用unbind()方法删除指定元素对象的click点击事件,语法为“元素对象.unbind();”。
scroll-view为滚动视图,分为水平滚动和垂直滚动,这篇文章主要给大家介绍了关于微信小程序scroll-view不能左右滑动问题的解决方法,需要的朋友可以参考下
这篇文章主要为大家详细介绍了js实现验证码案例,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008