一、自定义顶部导航

1.在某些时候,不想要自带的顶部导航栏,需要自己定义,这时可以将自定义的导航栏做成一个组件,然后做一下初始配置,在每个页面引用,初始化,即可得到一个自定义的顶部导航栏;

2.代码部分

2.1首先在app.json的window中配置"navigationStyle": "custom"(使用自定头部导航栏)

2.2导航栏组件部分

(1)custom-component.wxml

<!-- 组件 custom-component.wxml -->
<custom-component><view class='flex commonHead' style='color:{{myProperty.color?myProperty.color:"#000"}};background-color:{{myProperty.bg_color?myProperty.bg_color:"white"}};height:{{commonHeadHeight.titleHeight}}px;'><view class='commonHead-wrap flex'><!-- 0:无返回;1:返回上一级;2:home --><view class='commonHead_left'><view wx:if="{{myProperty.flag==1}}" class='commonHead_left_back' bindtap='commonHead_left_back'></view><view wx:if="{{myProperty.flag==2}}" class='commonHead_left_home' bindtap='commonHead_left_home'></view></view><view class='commonHead_right flex'><view class='commonHead_right_text line1'>{{myProperty.name?myProperty.name:"我是标题"}}</view></view></view></view>
</custom-component>

(2)custom-component.wxss

/*弹性布局*/.flex {display: -webkit-box;display: -moz-box;display: -ms-flexbox;display: -webkit-flex;display: flex;display: box;flex-wrap: wrap;
}.noWarp {flex-wrap: nowrap;
}/*元素居中*/.alignC {align-items: center;-webkit-box-align: center;-webkit-align-items: center;-moz-align-items: center;-ms-align-items: center;-o-align-items: center;
}/*水平排列*/.flexH {-webkit-box-orient: horizontal;-webkit-flex-direction: row;-moz-flex-direction: row;-ms-flex-direction: row;-o-flex-direction: row;flex-direction: row;
}/*垂直排列*/.flexV {-webkit-box-orient: vertical;-webkit-flex-direction: column;-moz-flex-direction: column;-ms-flex-direction: column;-o-flex-direction: column;flex-direction: column;
}/*两端对齐*/.flexSa {-webkit-box-pack: justify;justify-content: space-around;-webkit-justify-content: space-around;-moz-justify-content: space-around;-ms-justify-content: space-around;-o-justify-content: space-around;
}/*居中对齐*/.flexC {-webkit-box-pack: center;justify-content: center;-webkit-justify-content: center;-moz-justify-content: center;-ms-justify-content: center;-o-justify-content: center;
}.flexSb {justify-content: space-between;-webkit-justify-content: space-between;-moz-justify-content: space-between;-ms-justify-content: space-between;-o-justify-content: space-between;
}.flexS {-webkit-box-pack: start;justify-content: flex-start;-webkit-justify-content: flex-start;-moz-justify-content: flex-start;-ms-justify-content: flex-start;-o-justify-content: flex-start;
}.flexE {-webkit-box-pack: end;justify-content: flex-end;-webkit-justify-content: flex-end;-moz-justify-content: flex-end;-ms-justify-content: flex-end;-o-justify-content: flex-end;
}.line1 {white-space: nowrap;overflow: hidden;text-overflow: ellipsis;
}.commonHead {width: 100%;height: 128rpx;box-sizing: border-box;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;overflow: hidden;position: relative;z-index: 10;
}.commonHead-wrap {width: 100%;position: absolute;overflow: hidden;left: 0;bottom: 0;height: 45px;line-height: 45px;
}.commonHead_left {width: 100rpx;height: 100%;position: absolute;left: 0;top: 0
}.commonHead_left_back {width: 100%;height: 100%;background-image: url();background-size: 40rpx 40rpx;background-repeat: no-repeat;background-position: center;
}
.commonHead_left_home {width: 100%;height: 100%;background-image: url();background-size: 40rpx 40rpx;background-repeat: no-repeat;background-position: center;
}.commonHead_right {/* width: 450rpx; */width: 100%;height: 100%;line-height: 88rpx;text-align: center;font-size: 30rpx;overflow: hidden;justify-content:flex-end;
}.commonHead_right_text {/* width: 450rpx; */width: 280rpx;margin: 0 auto;
}

(3)custom-component.js

Component({properties: {myProperty: {type: Object,value: {"bg_color": "white","color": "#000","flag": 1,"name": "我是标题"}},commonHeadHeight: {type: Object,value: {}}},data: {}, // 私有数据,可用于模版渲染lifetimes: {// 生命周期函数,可以为函数,或一个在methods段中定义的方法名attached: function() {},moved: function() {},detached: function() {},},// 生命周期函数,可以为函数,或一个在methods段中定义的方法名attached: function() {}, // 此处attached的声明会被lifetimes字段中的声明覆盖ready: function() {var that = this;wx.getSystemInfo({success(res) {console.log(res.model)console.log(res.pixelRatio)console.log(res.windowWidth)console.log(res.windowHeight)console.log(res.screenHeight)console.log(res.language)console.log(res.version)console.log(res.statusBarHeight)that.setData({"commonHeadHeight.statusBarHeight": (34 * 2),"commonHeadHeight.titleHeight": res.statusBarHeight + 46});}})},pageLifetimes: {// 组件所在页面的生命周期函数show: function() {},},methods: {commonHead_left_back: function() {console.log("back")wx.navigateBack();},commonHead_left_home: function() {console.log("home")wx.reLaunch({url: '/pages/index/index'})}}})

(4)custom-component.json

{"component": true,"usingComponents": {}
}

2.3引用文件

(1)index.wxml

<!-- 页面的 WXML -->
<my-component my-property='{{aa}}' />
<view style='background-color:red'>hello world</view>

(2)index.js

const app = getApp()Page({data: { aa: {"bg_color": "orange","color": "#000","flag": 1,"name": "我是标题独一无二天下无敌我是标题独一无二天下无敌"}},onLoad: function () {},
})

(3)index.json

{"usingComponents": {"my-component": "/components/custom-component"}
}

3.效果(iPhone6,iPhone6s,iphoneX效果都蛮好的)

4.说明

5.推荐

博客:https://www.jianshu.com/p/7393c800ba09

博客:https://www.jianshu.com/p/5753a0e1754f

二、自定义tabBar

1.官方:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/custom-tabbar.html

2.推荐:https://developers.weixin.qq.com/community/develop/article/doc/000caac50f4a38351f19596b35c813

小程序自定义头部导航栏(“navigationStyle“: “custom“),自定义tabBar相关推荐

  1. (转载)微信小程序自定义头部导航栏

    本文转载自微信小程序自定义头部导航栏 微信小程序自定义头部导航栏 先看下demo的效果: 最终要实现的效果: 在tabbar页面不显示左侧按钮: 分享出去的页面进入后不显示左侧返回按钮: 点击返回按钮 ...

  2. 微信小程序实现原生导航栏和自定义头部导航栏

    原生导航栏: 可以在 app.json 的 window 属性中或页面的 JSON 文件中设置 navigationBarTitleText(导航栏标题内容).navigationBarTextSty ...

  3. 微信小程序——沉浸式导航栏实现

    微信小程序--沉浸式导航栏实现 微信小程序中导航栏一般来说是默认的展示标题等等,可以做的样式改变仅仅能通过配置一些官方提供的属性来实现.除此之外小程序还提供了navigationStyle这个属性可以 ...

  4. uni-app实现小程序沉浸式导航栏/顶部组件占满导航栏

    uni-app实现小程序沉浸式导航栏/顶部组件占满导航栏 如果你只是想单纯的让屏幕最上方的那个组件(比如swiper)将通知栏(导航栏)填充满,那么你只需要在page.json文件中加入以下代码到你想 ...

  5. 微信小程序之顶部导航栏(选项卡)实例 —— 微信小程序实战系列(1)

    需求:顶部导航栏 效果图: wxml: <!--导航条--> <view class="navbar"><text wx:for="{{na ...

  6. 微信小程序--动态设置导航栏颜色

    微信小程序--动态设置导航栏颜色 既然要动态设置导航栏颜色,估计 自定义导航栏 也跑不了 关于动态设置导航栏颜色,微信小程序官方文档给出了一个API: wx.setNavigationBarColor ...

  7. 微信小程序标题栏和导航栏的设置 —— 微信小程序教程系列(7)

    设置标题栏 标题栏window 在app.json文件里面,通过window对象里面的属性进行设置 示例: app.json: 运行: 设置导航栏 导航栏TabBar 如果我们的小程序是一个多 tab ...

  8. 微信小程序制作顶部导航栏

    1问题描述 使用微信小程序开发者工具制作顶部导航栏. 2算法描述 首先就是对微信小程序开发者工具的配置,官网搜索后进入,选择稳定版,Windows64位下载. 然后点开开发者工具,选择小程序,点击图片 ...

  9. 微信小程序在底部导航栏使用扫一扫功能【代码可用】

    微信小程序在底部导航栏使用扫一扫功能 解决方案 uni-app 微信原生代码 在家躺着也能遇到奇奇怪怪的需求,这不,需要在微信小程序底部的导航栏中加一个扫一扫功能⭐╮( ̄﹏ ̄)╭⭐. 解决方案 在导航 ...

最新文章

  1. 【leetcode】85. Maximal Rectangle 0/1矩阵的最大全1子矩阵
  2. mysql查询时间between and_Mysql中用between...and...查询日期时注意事项
  3. 小米面试题:单词搜索
  4. Synchronize同步
  5. Special Permutation 构造,min_element,贪心(900)
  6. 白帽子讲web安全——认证与会话管理
  7. 异步线程AsyncTask_2示例(07)
  8. 高中理科不好学计算机,高一理科很差但想学理咋办
  9. Xcode 打包 framework
  10. 混沌数学之Lorenz(洛伦茨)吸引子
  11. RabbitMQ 工作模式二
  12. Ubuntu 14.04 Wine的安裝
  13. 利用Backtrader进行期权回测之五:用backtrader_plotting查看回测结果
  14. Lightly 在线编译
  15. 请教各位仁兄 ,如何给delphi7增加gdi+的功能?
  16. uni-app前端H5页面底部内容被tabbar遮挡的问题解决方案
  17. Win11安卓应用使用及环境配置教程
  18. open cv均值 中值 高斯 双边高斯 滤波及模糊
  19. Visual Studio2018无法加载pdb文件怎么办
  20. vue 实现简单表格分页功能

热门文章

  1. 大学实验室文献检索方法
  2. Manjaro系统更新,wifi用不了,解决方法
  3. Excel VBA开发自动发送邮件
  4. 智能小车红绿灯识别功能的实现(python,ubuntu)
  5. 大数据在地理信息系统的应用
  6. 人活着总是要有点精神的
  7. 用Python爬取手机壁纸,太简单了吧
  8. 害怕国内那林林总总的浏览器
  9. linux微软雅黑乱码,CentOS安装微软雅黑,解决drawImage中文乱码相关问题
  10. 实测:合宙ESP32C3开发板可以直接用Arduino开发