首页 > 其他分享 >uniapp 不显示原生导航

uniapp 不显示原生导航

时间:2023-06-14 09:22:39浏览次数:60  
标签:原生 uniapp 状态栏 自定义 前端 titleNView 导航

自定义导航栏使用注意

当navigationStyle设为custom或titleNView设为false时,原生导航栏不显示

// pages配置部分页面
{
    "path": "pages/default/systemError",
    "style": {
        "navigationBarTitleText": "系统异常",
        "navigationStyle": "custom"
    }
}
// 配置所有页面
"globalStyle": {
    "navigationBarTextStyle": "black",
    "navigationBarBackgroundColor": "transparent",
    "backgroundColor": "#fff",
    "navigationStyle":"custom",
    "h5": {
        "titleView": false,
        "type": "transparent"
    }
}

 

此时要注意几个问题:

  • 非H5端,手机顶部状态栏区域会被页面内容覆盖。这是因为窗体是沉浸式的原因,即全屏可写内容。uni-app提供了状态栏高度的css变量--status-bar-height,如果需要把状态栏的位置从前景部分让出来,可写一个占位div,高度设为css变量。
<template>
    <view>
        <view class="status_bar">
            <!-- 这里是状态栏 -->
        </view>
        <view> 状态栏下的文字 </view>
    </view>
</template>
<style>
    .status_bar {
        height: var(--status-bar-height);
        width: 100%;
    }
</style>
复制代码
  • 如果原生导航栏不能满足需求,推荐使用uni ui的自定义导航栏NavBar。这个前端导航栏自动处理了状态栏高度占位问题。
  • 前端导航栏搭配原生下拉刷新时,会有问题,包括
    • 微信小程序下iOS需要拉更长才能看到下拉刷新的三个点,而Android是从屏幕顶部下拉,无法从导航栏下方下拉。如果一定要从前端导航栏下拉,小程序下只能放弃原生下拉刷新,纯前端模拟,参考mescroll插件,但这样很容易产生性能问题。目前小程序平台自身没有提供更好的方案
    • App和H5下,原生下拉刷新提供了circle样式,可以指定offset偏移量(pages.json的app-plus下配置),自定义下拉圈出现的位置。在hello uni-app的扩展组件中有示例。
  • 非H5端,前端导航盖不住原生组件。如果页面有video、map、textarea(仅小程序)等原生组件,滚动时会覆盖住导航栏前端组件在渲染速度上不如原生导航栏,原生导航可以在动画期间渲染,保证动画期间不白屏,但使用前端导航栏,在新窗体进入的动画期间可能会整页白屏,越低端的手机越明显。
    • 如果是小程序下,可以使用cover-view来做导航栏,避免覆盖问题
    • 如果是App下,建议使用titleNViewsubNVue,体验更好
  • 以上讨论的是前端自定义导航栏,但在App侧,原生导航栏也提供了比小程序导航更丰富的自定义性页面禁用原生导航栏后,想要改变状态栏的前景字体样式,仍可设置页面的 navigationBarTextStyle 属性(只能设置为 black或white)。如果想单独设置状态栏颜色,App端可使用plus.navigator.setStatusBarStyle设置。注意部分低端Android手机(4.4)自身不支持设置状态栏前景色。
    • titleNView:给原生导航栏提供更多配置,包括自定义按钮、滚动渐变效果、搜索框等,详见titleNView
    • subNVue:使用nvue原生渲染,所有布局自己开发,具备一切自定义灵活度。详见subNVue

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

标签:原生,uniapp,状态栏,自定义,前端,titleNView,导航
From: https://www.cnblogs.com/angia/p/17479207.html

相关文章

  • KCD技术分享:以SBOM为基础的云原生应用安全治理
    随着越来越多的企业和组织将他们的应用迁移到云上,云原生技术的应用部署和管理正在变得更加灵活和高效,但也相应地引入了一些新的安全风险。2023年4月15日,由云原生计算基金会(CNCF)发起,全球各国当地的CNCF大使、员工以及CNCF会员单位联合组织的KubernetesCommunityDays(KCD)技术沙......
  • uniapp开发公众号H5时用户缓存无法清除问题
     业务场景:  此项目是一个vx公众号h5项目,每次更新版的时候用户端由于有缓存,每次都是使用滞后的版本解决方案:一、index.html文件如何保证不缓存,每次都使用服务器上最新的代码?此时需要一下标签:<metahttp-equiv="Cache-Control"content="no-cache,no-store,must-revali......
  • 4500字聊聊云原生数据库
    云计算的快速发展,打破了传统技术架构的高壁垒,加速创新技术的普及和应用,帮助企业减少信息基础设施投入、降低软硬件运维人力成本、消除软件合规问题、保障数据安全。在云计算大势的推动之下,数据库作为云计算关键技术和最基础的服务之一,同样需要不断进化以适应新的场景需求,“生于云,长......
  • 微信原生小程序从0到1的基本配置
     首先,先去注册一个微信小程序,打开以下地址去注册。https://mp.weixin.qq.com/cgi-bin/wx注册完了之后到这个地址去进行扫码登录https://mp.weixin.qq.com/ 登录之后找到以下地方 复制AppID,后面有用。然后去下载一个微信开发者工具,这是地址https://develope......
  • 互动云渲染——云原生渲染的初步探索
    随着游戏及软件云端化运行能力的支持,大型游戏和软件可以在浏览器、轻客户端以及小程序中运行,在扩展了使用场景边界的同时,也为游戏和软件探索云原生实现提供了基础。腾讯云云渲染PaaS提供了基于WebRTC的万人级互动交互的云原生能力,包括操作权限转移管理、多人语音会话等,在本次Li......
  • 云原生的基本概念及架构
    云原生技术是近年来迅速发展的一种技术体系,它可以帮助企业更快速、更高效地构建和管理应用程序。本文将介绍云原生的概念、架构和相关技术。一、云原生的概念云原生是一种新兴的应用程序开发和部署方式,它强调了应用程序的可移植性、可扩展性和自动化。云原生应用程序通常是基于容......
  • 云原生之使用docker部署nginx网站
    (云原生之使用docker部署nginx网站)一、检查本地系统版本[root@node~]#cat/etc/os-releaseNAME="CentOSLinux"VERSION="7(Core)"ID="centos"ID_LIKE="rhelfedora"VERSION_ID="7"PRETTY_NAME="CentOSLinux7(Core)"......
  • 解密华为云原生媒体网络如何保障实时音视频服务质量
    随着5G和AI的发展,内容表达视频化成为了当今的主流,很多行业对视频分发有非常旺盛的需求。我们非常荣幸地请到了华为云的资深视频架构师黄挺,为大家介绍基于互联网的实时音视频服务所面临的挑战,分享华为云原生媒体网络全方位保障实时音视频服务体验的实践。文/黄挺整理/LiveVideoS......
  • 云原生周刊:DevOps-resources
    推荐一个GitHub仓库“DevOps-resources”。这个GitHub仓库包含了学习和实践DevOps所需的资源列表。它包括涉及云计算、容器化、微服务、自动化和安全问题的文章、书籍、课程和工具。资源按最佳实践、代码基础设施和安全性等类别进行排序,使得用户可以更轻松地找到与他们需求......
  • Delphi 原生支持DataSet导出Json
    Xalion发现data.DBJson单元,不知什么时候加的,官方帮助中也没有写。procedureTForm18.Button2Click(Sender:TObject);varcV:TDatasetToJSONBridge;jo:Tjsonobject;begincV:=TDatasetToJSONBridge.Create;trycV.Dataset:=mt;jo:=Tjsonobject(cV.......