uniapp 之 微信小程序、支付宝小程序 对于自定义导航栏的不同

目录

前言

微信小程序

代码

支付宝小程序

首页配置文件

[二级菜单页面 配置](#二级菜单页面 配置)

总结

不同

相同


前言

小程序都是 uni-app 写的 不是原生

微信小程序

代码

pages.json文件中配置

重点: "navigationStyle": "custom", // 导航栏样式

javascript 复制代码
{
      "path": "pages/home/home",
      "style": {
        "navigationBarTitleText": "首页",
        "navigationStyle": "custom",
        // 开始下拉刷新
        "enablePullDownRefresh": true,
        // 上拉触底的距离
        "onReachBottomDistance": 150
      }
    },

首页 vue文件

template

javascript 复制代码
 <view class=" " :style="{'height':topHeight+'px'}"></view>

script

javascript 复制代码
data中定义
   
     topHeight: 20,

onLoad(){

   const {
        height,
        top
      } = uni.getMenuButtonBoundingClientRect();
      this.topHeight = height + top

}

备注:

height:是胶囊的高度

支付宝小程序

首页配置文件

pages.json文件

重要:"transparentTitle": "always", // 导航栏透明设置

javascript 复制代码
{
      "path": "pages/home/home",
      "style": {
        "transparentTitle": "always",
        // "navigationBarTitleText": "首页",
        // "navigationStyle": "custom",
        // 开始下拉刷新
        "enablePullDownRefresh": true,
        // 上拉触底的距离
        "onReachBottomDistance": 150
      }
    },

首页 vue 页面

template

javascript 复制代码
 <view :style="{'height':topHeight+'px'}" />
 <view :style="{'height':titleHeight+'px'}" style="text-align: center;">你好</view>

script

javascript 复制代码
data中 定义

topHeight: 20,
titleHeight: 0,


onLoad 中 
 const {
        height,
        top
      } = uni.getMenuButtonBoundingClientRect();
      this.topHeight = top // 顶部到胶囊的高度 54
      this.titleHeight = height // 胶囊的高

样式

二级菜单页面 配置

只需要加

"navigationBarTitleText": "站点详情"

javascript 复制代码
{
      "root": "subpkg",
      "pages": [{
          "path": "service/service",
          "style": {
            "enablePullDownRefresh": true,
            "navigationBarTitleText": "站点详情",
            "transparentTitle": "always",
            "onReachBottomDistance": 150
          }

        },

详情页样式 详情页 vue文件 不需要获取设备的宽高属性

总结

不同

  1. 微信小程序在 pages.json 中配置导航栏样式

"navigationStyle": "custom"

而 支付宝小程序 在pages.json 中配置导航栏透明度

"transparentTitle": "always",

  1. 配置导航栏标题文字内容

"navigationBarTitleText": "站点详情",

微信小程序 在配置导航栏样式后在配置 这个属性,则在页面不会显示 标题文字内容

而 支付宝小程序配置 此属性 则在页面上显示标题文字内容 (若在二级页面时 也会出现返回上一级的箭头)

相同

获取导航栏顶部到胶囊顶部 以及 胶囊高度的方法都是一样的

相关推荐
杰建云16712 小时前
小程序商城店铺装修怎么做
小程序
2501_9151063215 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
万能小林子17 小时前
2026 AI开发新范式:Vibe Coding生成网页 + 3分钟打包成App,非技术人也能独立发布自己的App!
人工智能·uni-app·ai编程·web app·vibecoding
weikecms18 小时前
CPS返利小程序一键搭建教程
小程序
白菜__18 小时前
微信小程序网关逆向分析
javascript·微信小程序·小程序·node.js·网络爬虫·微信网关·小程序网关
TANKING-18 小时前
微信小程序订阅消息推送系统(一次性/长期订阅消息推送)
微信小程序·小程序
李白的天不白18 小时前
小程序not 404
小程序
我是伪码农19 小时前
小程序75-100
小程序
一颗小青松19 小时前
uniapp 集成友盟并且上传页面路径
前端·vue.js·uni-app