微信小程序的自带头部、自定义创建-前端-E先生的博客
Java
MySQL
大数据
Python
前端
黑科技
大语言模型
    首页 >> 互联网 >> 前端

微信小程序的自带头部、自定义创建

[导读]:在进行微信小程序的开发中微信小程序的头部会默认生成一个头部,用来展示每个pages页面标题,可以在app.json中的window中进行配置,但是它自身带的头部,只是能简单的配置,比如添加文字,背景颜色等等。但是有时候这些配置无法满足我们对于头部的要求,可能我们会想添加一个图标或者进行多样化的布局,这个时候我们就要把微...

在进行微信小程序的开发中微信小程序的头部会默认生成一个头部,用来展示每个pages页面标题,可以在app.json中的window中进行配置,但是它自身带的头部,只是能简单的配置,比如添加文字,背景颜色等等。

但是有时候这些配置无法满足我们对于头部的要求,可能我们会想添加一个图标或者进行多样化的布局,这个时候我们就要把微信小程序自带的头部移除创建自己的头部样式。

在app.json 的window中配置: "navigationStyle":"custom"

导航栏样式,仅支持 default/custom。custom即取消默认的原生导航栏,需看使用注意

如果原生导航栏不能满足需求,推荐使用uni ui的自定义导航栏NavBar (opens new window)。这个前端导航栏自动处理了状态栏高度占位问题。

前端导航栏搭配原生下拉刷新时,会有问题,包括

  1. 微信小程序下iOS需要拉更长才能看到下拉刷新的三个点,而Android是从屏幕顶部下拉,无法从导航栏下方下拉。如果一定要从前端导航栏下拉,小程序下只能放弃原生下拉刷新,纯前端模拟,参考mescroll插件 (opens new window),但这样很容易产生性能问题。目前小程序平台自身没有提供更好的方案

  2. App和H5下,原生下拉刷新提供了circle样式,可以指定offset偏移量(pages.json的app-plus下配置),自定义下拉圈出现的位置。在hello uni-app的扩展组件中有示例。

  3. 非H5端,前端导航盖不住原生组件。如果页面有video、map、textarea(仅小程序)等原生组件,滚动时会覆盖住导航栏

如果是小程序下,可以使用cover-view来做导航栏,避免覆盖问题

如果是App下,建议使用titleNView或subNVue,体验更好

前端组件在渲染速度上不如原生导航栏,原生导航可以在动画期间渲染,保证动画期间不白屏,但使用前端导航栏,在新窗体进入的动画期间可能会整页白屏,越低端的手机越明显。

以上讨论的是前端自定义导航栏,但在App侧,原生导航栏也提供了比小程序导航更丰富的自定义性

titleNView:给原生导航栏提供更多配置,包括自定义按钮、滚动渐变效果、搜索框等,详见titleNView

subNVue:使用nvue原生渲染,所有布局自己开发,具备一切自定义灵活度。详见subNVue

页面禁用原生导航栏后,想要改变状态栏的前景字体样式,仍可设置页面的 navigationBarTextStyle 属性(只能设置为 black或white)。如果想单独设置状态栏颜色,App端可使用plus.navigator.setStatusBarStyle (opens new window)设置。注意部分低端Android手机(4.4)自身不支持设置状态栏前景色。

鉴于以上问题,在原生导航能解决业务需求的情况下,尽量使用原生导航。甚至有时需要牺牲一些不是很重要的需求。在App和H5下,uni-app提供了灵活的处理方案:titleNView、subNVue、或整页使用nvue。但在小程序下,因为其自身的限制,没有太好的方案。有必要的话,也可以用条件编译分端处理。

image.png


本文来自E先生的博客,如若转载,请注明出处:https://www.javajz.cn

留言区

联系人:
手   机:
内   容:
验证码:

历史留言

欢迎加Easy的QQ