Small program custom head navigation needs to calculate the height of different models navigation.

First, calculate the head height

  • 1. Graphical analysis

  • 2. Calculation code

Note: All units are computed px

Const {statusBarHeight} = wx.getSystemInfosync (); / / capsule button location information height and distance from the top of the const {height, top} = wx. GetMenuButtonBoundingClientRect (); // navigateHeight = (top-statusbarheight)*2+height const navigateHeight = (top-statusbarheight)*2+height;Copy the code

Customizing navigation components

Note: After calculating the dimensions, we need to build the shelf of components.

  • 1. Create a custom component

Create the Components folder in the root directory and then create the corresponding component

  • 2. Build shelves

Use the calculated navigation bar height, status bar height and capsule button information to calculate the size

  • 3. Code examples

Component js

. Lifetimes: {attached() {// Calculate header information this.calcnavigation (); }},... Methods: {calcNavigation(){const {statusBarHeight} = wx.getSystemInfosync (); / / capsule button location information height and distance from the top of the const {height, top} = wx. GetMenuButtonBoundingClientRect (); // navigateHeight = (top-statusbarheight)*2+height const navigateHeight = (top-statusbarheight)*2+height; This. setData({statusBarHeight, navigateHeight, menuHeight: height})},}...Copy the code

Component WXML

<cover-view class="na-bar" style="height: {{navigateHeight}}px; padding-top: {{statusBarHeight}}px;" > <slot></slot> </cover-view>Copy the code

Note: Padding-top is used for the background color that may need to be used in the navigation. If it is margin-top, set the background color, and the top part will have no color.

Addendum: legend of margin-top

Component WXSS

.na-bar { width: 100vw; position: fixed; /* set float */ left: 0; top: 0; z-index: 10086; display: flex; background: #f00; /* Background color can be customized or cancelled */}Copy the code

Three, page use components

Note: Before importing a component, you need to configure a custom navigation header on the current page

  • 1. In.jsonTo configure a custom
"NavigationStyle ": "custom", "navigationBarTextStyle": "navigationBarTextStyle": "White ", // Set the default phone type at the top of the color remember to remove the comment "usingComponents": {// import components, remember to remove the comment "navigationBar": "/components/navigationBar/navigationBar" } }Copy the code
  • In 2..wxmlUse & customize your navigation content
<navigationBar>
  ...
</navigationBar>
Copy the code

PS: There are some simple cases below, and the details need to be improved by yourself.

Case 1

Product details page custom

  • 1. Modify the red background of the definition

We can set the background page by setting the component to pass the background color

<navigationBar navigate-background="#ffffff">
  ...
</navigationBar>
Copy the code

Component.js, receives the parameters passed

. NavigateBackground: {type: String, value: 'transparent' // Default is transparent}},...Copy the code

Component used in WXML

<cover-view class="na-bar" style="height: {{navigateHeight}}px; padding-top: {{statusBarHeight}}px; background:{{navigateBackground}};" > <slot></slot> </cover-view>Copy the code

PS: Don’t forget to remove the background color from the component

  • 2. Start writing the layout

Page. WXML

<navigationBar navigate-background="#ffffff"> <cover-view class="bar"> <cover-view class="bar-left"> <cover-image SRC ="/images/back.png" mode="aspectFill"></cover-image> </cover-view> <cover-view class="bar-center"> <cover-view class="bar-right"></cover-view> </cover-view> </navigationBar>Copy the code

Page. WXSS

.bar {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100vw;
  height: 100%;
}
.bar-left {
  width: 80rpx;
  /* background: #00f; */
  height: 100%;
  display: flex;
  flex-direction: row;
  /* justify-content: center; */
  align-items: center;
}
.bar-left cover-image {
  width: 28rpx;
  height: 28rpx;
  margin-left: 20rpx;
}
.bar-center {
  color: #333;
}
.bar-right {
  width: 80rpx;
  height: 100%;
}
Copy the code

Use flex layout, then create three blocks bar-left bar-center bar-right, where bar-center is the middle content, bar-right is combined with flex layout to occupy the pit, bar-left is used to put the back button. Context-content with Flex layout: space between; Fixed bar-left&bar-right width values can be defined as required.

5. Case 2

Note: the head put the search bar, this is relatively simple, directly write style on the line PS: background map changed Page. WXMLIn the

<navigationBar> <cover-view class="bar"> <cover-view class="searchBar"> <cover-image class="search-icon" SRC ="/images/search.png"></cover-image> <cover-view class="search-words"> Please enter the product you want to search </cover-view> </cover-view> </cover-view> </navigationBar>Copy the code

Page. WXSS

.bar { display: flex; flex-direction: row; align-items: center; width: 100vw; height: 100%; } .searchBar { display: flex; flex-direction: row; align-items: center; Background: rgba (255, 255, 255, 0.2); padding:10rpx 30rpx 10rpx 10rpx; border-radius: 60rpx; margin-left: 30rpx; } .search-icon { width: 40rpx; height: 40rpx; margin-right: 10rpx; } .search-words { font-size: 26rpx; color: #fff; }Copy the code