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


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 相关文章推荐
node.js chat程序如何实现Ajax long-polling长链接刷新模式
Mar 13 Javascript
textarea 控制输入字符字节数(示例代码)
Dec 27 Javascript
使用JavaScript和C#中获得referer
Nov 14 Javascript
jQuery实现在textarea指定位置插入字符或表情的方法
Mar 11 Javascript
js实现的星星评分功能函数
Dec 09 Javascript
JavaScript Math.round() 方法
Dec 18 Javascript
js实现右键自定义菜单
Dec 03 Javascript
基于Bootstrap漂亮简洁的CSS3价格表(附源码下载)
Feb 28 Javascript
bootstrap3中container与container_fluid外层容器的区别讲解
Dec 04 Javascript
基于vue监听滚动事件实现锚点链接平滑滚动的方法
Jan 17 Javascript
解决小程序无法触发SESSION问题
Feb 03 Javascript
使用Vue 自定义文件选择器组件的实例代码
Mar 04 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
星际争霸 Starcraft 秘技补丁
2020/03/14 星际争霸
php mysql Errcode: 28 终极解决方法
2009/07/01 PHP
PHP中error_log()函数的使用方法
2015/01/20 PHP
学习php设计模式 php实现策略模式(strategy)
2015/12/07 PHP
PHP登录验证码的实现与使用方法
2016/07/07 PHP
php基于websocket搭建简易聊天室实践
2016/10/24 PHP
利用laravel搭建一个迷你博客实战教程
2017/08/13 PHP
jquery插件 cluetip 关键词注释
2010/01/12 Javascript
javascript基础知识大集锦(二) 推荐收藏
2011/01/13 Javascript
javascript 函数声明与函数表达式的区别介绍
2013/10/05 Javascript
JS实现按比例缩放图片的方法(附C#版代码)
2015/12/08 Javascript
基于JS实现密码框(password)中显示文字提示功能代码
2016/05/27 Javascript
JS定时器使用,定时定点,固定时刻,循环执行详解
2016/05/31 Javascript
javacript获取当前屏幕大小
2016/06/04 Javascript
AngularJS bootstrap启动详解及实例代码
2016/09/14 Javascript
纯JS实现简单的日历
2017/06/26 Javascript
详解vue-cli中使用rem,vue自适应
2019/05/06 Javascript
小程序绑定用户方案优化小结
2019/05/15 Javascript
vue3.0中使用postcss-pxtorem的具体方法
2019/11/20 Javascript
[01:07:46]完美世界DOTA2联赛循环赛 Magma vs IO BO2第二场 11.01
2020/11/02 DOTA
Python中字典的setdefault()方法教程
2017/02/07 Python
解决python测试opencv时imread导致的错误问题
2019/01/26 Python
Django为窗体加上防机器人的验证码功能过程解析
2019/08/14 Python
Python实现猜年龄游戏代码实例
2020/03/25 Python
纯CSS实现设置半个字符的样式
2014/07/03 HTML / CSS
CSS3实现多重边框的方法总结
2016/05/31 HTML / CSS
深入浅析CSS3中的Flex布局整理
2020/04/27 HTML / CSS
英国第二大营养品供应商:Vitabiotics
2016/10/01 全球购物
关于Assembly命名空间的三个面试题
2015/07/23 面试题
大学生实习自我鉴定
2013/12/11 职场文书
优秀毕业生自我鉴定
2014/01/19 职场文书
财务会计大学生自我评价
2014/04/09 职场文书
给校长的建议书600字
2014/05/15 职场文书
农业局党的群众路线教育实践活动整改方案
2014/09/20 职场文书
干部理论学习心得体会
2016/01/21 职场文书
python解析照片拍摄时间进行图片整理
2022/07/23 Python