微信小程序自定义导航栏实例代码


Posted in Javascript onApril 05, 2019

背景

在做快狗打车小程序时,关于默认导航栏,我们遇到了以下的问题:

  • Android、IOS手机对于页面title的展示不一致,安卓title的显示不居中
  • 页面的title只支持纯文本级别的样式控制,不能够做更丰富的title效果
  • 左上角的事件无法监听、定制
  • 路由导航单一,只能够返回上一页,深层级页面的返回不够友好

我们希望的是:在各个机型页面上title一致性 & 个性化展示、取得左上角点击事件控制权及深层级页面的一键返回

实现

step1 自定义

第一步 取得导航栏的控制权

小程序支持自定义导航栏,只需要在app.json文件中,window项中配置

"navigationStyle": "custom"

这样微信就放开了导航栏的控制权,只保留右上角的胶囊。

页面会从视窗的顶部开始渲染,如图

微信小程序自定义导航栏实例代码

接下来,我们要做的就是实现一个导航栏组件,把它放置在页面原来的默认导航栏的位置,内容什么的完全由开发者自己定制。

step2 功能点

第二步 梳理导航栏的功能点

  • 导航栏高度(各个机型动态适配)
  • 导航栏内容定制
    • 所有机型title居中显示(自己布局实现)
    • 首页导航栏左上角显示个人中心、中部title使用个性图标
    • 嵌套页面左上角显示返回上一页 + 回到首页按钮
    • 非常规首页左上角显示回到首页按钮

导航栏高度 包含两个部分:工具栏和title栏, 工具栏的高度一般是固定的20px,title栏的高度需要计算

导航栏内容的定制,需要识别当前页面的性质,根据不同的页面展示不同的内容,可以通过获取当前的页面路由栈来判定当前的页面性质

微信小程序自定义导航栏实例代码

step3 导航栏组件基本结构

目前快狗打车小程序的基本结构

// navBar.wxml
<cover-view class='place-holder'></cover-view>
<cover-view class='nav-bar'>
 <cover-view class='tool-bar' style='height: 20px'></cover-view>
 <cover-view class='title-bar'>
  <cover-view class='left-cell'>
   // scene0 常规首页 个人中心按钮
   // scene1 非常规首页 回首页按钮
   // scene2 嵌套页  返回上一页按钮 + 回首页按钮
  </cover-view>
  <cover-view class='center-cell'>
   // scene0 常规首页 个性化title
   // scene1 其他页 正常title
  </cover-view>
  <cover-view class='right-cell'>
   // 占位用的
  </cover-view>
 </cover-view>
</cover-view>

Tips:

组件内多了一个占位的place-holder块,是因为某些页面有类似滚动列表的需求,要保证导航栏始终在视窗的顶部的话,需要使用定位,定位之后脱离文档流,在最初的时候需要占位块保证后续的页面内容不会被导航栏遮挡

使用cover-view布局是因为快狗的业务中有类似map的原生组件,使用view的话有被遮挡的风险

step4 高度计算

需要计算title-bar的高度

在 默认导航栏 & 无底部tab栏 的情况下,使用wx.getSystemInfoSync获取手机信息,可以看到两项信息:

  • screenHeight 屏幕高度,单位px
  • windowHeight 可使用窗口高度,单位px

这种情况下,二者的差值就是默认的导航栏的高度, 但是在设置了"navigationStyle": "custom"之后,二者的值是一样的了,因此导航栏的高度我们需要使用统计的经验值。

根据统计,得到如下的结果:

{
 'iPhone': 64,
 'iPhoneX': 88,
 'Android': 68,
 'samsung': 72
}

工具栏的高度可根据wx.getSystemInfoSync返回值中的statusBarHeight获取。

至此,我们得到了导航栏的相关的高度值

// 导航栏总高度 & 占位块高度
placeHoder = totalBar = {
 'iPhone': 64,
 'iPhoneX': 88,
 'Android': 68,
 'samsung': 72
}
// 时间、信号等工具栏的高度
toolBar = systermInfo.statusBarHeight
// 页面title栏的高度
titleBar = totalBar - toolBar

step5 内容定制

在组件的生命周期函数attached中,我们可以获取当前的页面路由栈

let pages = getCurrentPages()
let current_page = pages[pages.length - 1].route 
const NORMAL_ENTRY = '常规的入口页路径'

// scene 0 常规入口页 个性化title、个人中心
pages.length === 1 && current_page === NORMAL_ENTRY
// scene 1 非常规入口页 回首页
pages.length === 1 && current_page !== NORMAL_ENTRY
// scene 2 嵌套页面 返回 + 回首页
pages.length > 1

根据不同的条件,展示不同的内容

最终效果

scene 0 常规首页

微信小程序自定义导航栏实例代码

scene 1 非常规首页

微信小程序自定义导航栏实例代码

scene 2 嵌套页

微信小程序自定义导航栏实例代码

目前在生产环境99%的机型中,都可以完美的运行。

写在最后

  • 自定义导航栏是全局生效的,一旦设置,各个原生小程序页面都需要引入
  • 目前微信版本7+支持了针对特定页面的自定义导航栏,可以根据需要个性化定制
  • 自定义导航栏在web-view页面不会起效
  • 有尝试把导航栏做成插件,但是遇到在插件组件中无法获取页面路由栈的问题,因此没有成功

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
用jquery实现输入框获取焦点消失文字
Apr 27 Javascript
jquery设置元素的readonly和disabled的写法
Sep 22 Javascript
可自定义速度的js图片无缝滚动示例分享
Jan 20 Javascript
Js中使用hasOwnProperty方法检索ajax响应对象的例子
Dec 08 Javascript
JS实现按比例缩放图片的方法(附C#版代码)
Dec 08 Javascript
jQuery实现产品对比功能附源码下载
Aug 09 Javascript
分享JS数组求和与求最大值的方法
Aug 11 Javascript
jQuery中map函数的两种方式
Apr 07 jQuery
JS+canvas实现的五子棋游戏【人机大战版】
Jul 19 Javascript
详解vue填坑之解决部分浏览器不支持pushState方法
Jul 12 Javascript
怎么使用javascript深度拷贝一个数组
Jun 06 Javascript
Vue自定义render统一项目组弹框功能
Jun 07 Javascript
Node.js事件的正确使用方法
Apr 05 #Javascript
利用Node.js如何实现文件循环覆写
Apr 05 #Javascript
详解JavaScript栈内存与堆内存
Apr 04 #Javascript
jQuery中实现text()的方法
Apr 04 #jQuery
基于 jQuery 实现键盘事件监听控件
Apr 04 #jQuery
详解微信图片防盗链“此图片来自微信公众平台 未经允许不得引用”的解决方案
Apr 04 #Javascript
基于Vue+elementUI实现动态表单的校验功能(根据条件动态切换校验格式)
Apr 04 #Javascript
You might like
zend api扩展的php对象的autoload工具
2011/04/18 PHP
php 获取xml接口数据的处理方法
2018/05/31 PHP
用JavaScript实现仿Windows关机效果
2007/03/10 Javascript
理解JavaScript的caller,callee,call,apply
2009/04/28 Javascript
Javascript异步编程的4种方法让你写出更出色的程序
2013/01/17 Javascript
js 验证密码强弱的小例子
2013/03/21 Javascript
JavaScript实现鼠标滑过处生成气泡的方法
2015/05/16 Javascript
jQuery实现ajax调用WCF服务的方法(附带demo下载)
2015/12/04 Javascript
js中less常用的方法小结
2017/08/09 Javascript
vue-cli2.x项目优化之引入本地静态库文件的方法
2018/06/19 Javascript
vue devtools的安装与使用教程
2018/08/08 Javascript
vuex2中使用mapGetters/mapActions报错的解决方法
2018/10/20 Javascript
vue拖拽排序插件vuedraggable使用方法详解
2020/08/21 Javascript
react写一个select组件的实现代码
2019/04/03 Javascript
django js 实现表格动态标序号的实例代码
2019/07/12 Javascript
vue中的mescroll搜索运用及各种填坑处理
2019/10/30 Javascript
Vue自定义组件的四种方式示例详解
2020/02/28 Javascript
Python实现读取文件最后n行的方法
2017/02/23 Python
Python算术运算符实例详解
2017/05/31 Python
浅谈python numpy中nonzero()的用法
2018/04/02 Python
在PyTorch中Tensor的查找和筛选例子
2019/08/18 Python
Python使用QQ邮箱发送邮件实例与QQ邮箱设置详解
2020/02/18 Python
Python爬虫中Selenium实现文件上传
2020/12/04 Python
moosejaw旗下的户外商品促销网站:Mountain Steals
2017/02/27 全球购物
在线购买廉价折扣书籍和小说:BookOutlet.com
2018/02/19 全球购物
超市创业计划书
2014/04/24 职场文书
敬老月活动总结
2014/08/28 职场文书
党的群众路线教育实践活动个人对照检查材料(教师)
2014/11/04 职场文书
会计工作态度自我评价
2015/03/06 职场文书
开除员工通知
2015/04/22 职场文书
党员志愿者服务倡议书
2015/04/29 职场文书
工会文体活动总结
2015/05/07 职场文书
离婚起诉状范本
2015/05/19 职场文书
摩登时代观后感
2015/06/03 职场文书
redis限流的实际应用
2021/04/24 Redis
WIN10使用IIS部署ftp服务器详细教程
2022/08/05 Servers