亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序自定義navigationBar頂部導航欄適配所有機型(附完整案例)

 更新時間:2020年04月26日 09:22:38   作者:FaxMiao  
這篇文章主要介紹了微信小程序自定義navigationBar頂部導航欄適配所有機型(附完整案例),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

navigationBar相信大家都不陌生把?今天我們就來說說自定義navigationBar,把它改變成我們想要的樣子(搜索框+膠囊、搜索框+返回按鈕+膠囊等)。

思路

  • 隱藏原生樣式
  • 獲取膠囊按鈕、狀態(tài)欄相關數(shù)據(jù)以供后續(xù)計算
  • 根據(jù)不同機型計算出該機型的導航欄高度,進行適配
  • 編寫新的導航欄
  • 引用到頁面

正文

一、隱藏原生的navigationBar

window全局配置里有個參數(shù):navigationStyle(導航欄樣式),default=默認樣式,custom=自定義樣式。

"window": {
	"navigationStyle": "custom"
}

讓我們看看隱藏后的效果:

可以看到原生的navigationBar已經(jīng)消失了,剩下孤零零的膠囊按鈕,膠囊按鈕是無法隱藏的。

二、準備工作

1.獲取膠囊按鈕的布局位置信息

我們用wx.getMenuButtonBoundingClientRect() 【官方文檔】 獲取膠囊按鈕的布局位置信息,坐標信息以屏幕左上角為原點:

const menuButtonInfo = wx.getMenuButtonBoundingClientRect();

width height top right bottom left
寬度 高度 上邊界坐標 右邊界坐標 下邊界坐標 左邊界坐標

下面是官方給的示意圖,方便大家理解幾個坐標。

2.獲取系統(tǒng)信息

用wx.getSystemInfoSync() 【官方文檔】 獲取系統(tǒng)信息,里面有個參數(shù):statusBarHeight(狀態(tài)欄高度),是我們后面計算整個導航欄的高度需要用到的。

const systemInfo = wx.getSystemInfoSync();

三、計算公式

我們先要知道導航欄高度是怎么組成的, 計算公式: 導航欄高度 = 狀態(tài)欄到膠囊的間距(膠囊距上距離-狀態(tài)欄高度) * 2 + 膠囊高度 + 狀態(tài)欄高度 。

實例 【源碼下載

自定義導航欄會應用到多個、甚至全部頁面,所以封裝成組件,方便調用;下面是我寫的一個簡單例子:

app.js

App({
 onLaunch: function(options) {
  const that = this;
  // 獲取系統(tǒng)信息
  const systemInfo = wx.getSystemInfoSync();
  // 膠囊按鈕位置信息
  const menuButtonInfo = wx.getMenuButtonBoundingClientRect();
  // 導航欄高度 = 狀態(tài)欄到膠囊的間距(膠囊距上距離-狀態(tài)欄高度) * 2 + 膠囊高度 + 狀態(tài)欄高度
  that.globalData.navBarHeight = (menuButtonInfo.top - systemInfo.statusBarHeight) * 2 + menuButtonInfo.height + systemInfo.statusBarHeight;
  that.globalData.menuRight = systemInfo.screenWidth - menuButtonInfo.right;
  that.globalData.menuBotton = menuButtonInfo.top - systemInfo.statusBarHeight;
  that.globalData.menuHeight = menuButtonInfo.height;
 },
 // 數(shù)據(jù)都是根據(jù)當前機型進行計算,這樣的方式兼容大部分機器
 globalData: {
  navBarHeight: 0, // 導航欄高度
  menuRight: 0, // 膠囊距右方間距(方保持左、右間距一致)
  menuBotton: 0, // 膠囊距底部間距(保持底部間距一致)
  menuHeight: 0, // 膠囊高度(自定義內容可與膠囊高度保證一致)
 }
})

app.json

{
 "pages": [
  "pages/index/index"
 ],
 "window": {
  "navigationStyle": "custom"
 },
 "sitemapLocation": "sitemap.json"
}

下面為組件代碼: /components/navigation-bar/navigation-bar.wxml

<!-- 自定義頂部欄 -->
<view class="nav-bar" style="height:{{navBarHeight}}px;">
 <input class="search" placeholder="輸入關鍵詞!" style="height:{{menuHeight}}px; min-height:{{menuHeight}}px; line-height:{menuHeight}}px; left:{{menuRight}}px; bottom:{{menuBotton}}px;"></input>
</view>

<!-- 
 內容區(qū)域:
 自定義頂部欄用的fixed定位,會遮蓋到下面內容,注意設置好間距
-->
<view class="content" style="margin-top:{{navBarHeight}}px;"></view>

/components/navigation-bar/navigation-bar.json

{
 "component": true
}

/components/navigation-bar/navigation-bar.js

const app = getApp()
Component({
 properties: {
  // defaultData(父頁面?zhèn)鬟f的數(shù)據(jù)-就是引用組件的頁面)
  defaultData: {
   type: Object,
   value: {
    title: "我是默認標題"
   },
   observer: function(newVal, oldVal) {}
  }
 },
 data: {
  navBarHeight: app.globalData.navBarHeight,
  menuRight: app.globalData.menuRight,
  menuBotton: app.globalData.menuBotton,
  menuHeight: app.globalData.menuHeight,
 },
 attached: function() {},
 methods: {}
})

/components/navigation-bar/navigation-bar.wxss

.nav-bar{ position: fixed; width: 100%; top: 0; color: #fff; background: #000;}
.nav-bar .search{ width: 60%; color: #333; font-size: 14px; background: #fff; position: absolute; border-radius: 50px; background: #ddd; padding-left: 14px;}

以下是調用頁面的代碼,也就是引用組件的頁面: /pages/index/index.wxml

navigation-bar default-data="{{defaultData}}"></navigation-bar>

/pages/index/index.json

{
 "usingComponents": {
  "navigation-bar": "/components/navigation-bar/navigation-bar"
 }
}

/pages/index/index.js

const app = getApp();
Page({
 data: {
  // 組件參數(shù)設置,傳遞到組件
  defaultData: {
   title: "我的主頁", // 導航欄標題
  }
 },
 onLoad() {
  console.log(this.data.height)
 }
})

效果圖:

好了,以上就是全部代碼了,大家可以文中復制代碼,也可以 【下載源碼

,直接到開發(fā)者工具里運行,記得appid用自己的或者測試哦!

下面附幾張其它小程序的效果圖,大家也可以嘗試照著做:

總結

本文寫了自定義navigationBar的一些基礎性東西,里面涉及組件用法、參數(shù)傳遞、導航欄相關。

由于測試環(huán)境有限,大家在使用時如果發(fā)現(xiàn)有什么問題,希望及時反饋,以供及時更新幫助更多的人!

到此這篇關于微信小程序自定義navigationBar頂部導航欄適配所有機型(附完整案例)的文章就介紹到這了,更多相關小程序navigationBar頂部導航欄內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • div層的移動及性能優(yōu)化

    div層的移動及性能優(yōu)化

    層的移動本來很簡單,用jquery插件或者自己寫一個也不難,但是最近一個ipad項目里,發(fā)現(xiàn)用手移動div會感覺很卡,體驗很差(可能是ipad的配置根不上pc)。
    2010-11-11
  • 關于JavaScript中JSON的5個小技巧分享

    關于JavaScript中JSON的5個小技巧分享

    這篇文章主要和大家分享五個JavaScript中的JSON技巧,例如:隱藏字符串化數(shù)據(jù)中的某些屬性、創(chuàng)建自定義輸出格式等,感興趣的小伙伴可以了解一下
    2022-03-03
  • js圖片跟隨鼠標移動代碼

    js圖片跟隨鼠標移動代碼

    大家瀏覽網(wǎng)頁的時候,見到過圖片跟隨鼠標移動的js特效,效果非常好,是怎么實現(xiàn)的呢,實現(xiàn)這個功能很簡單,感興趣的朋友一起看看吧
    2015-11-11
  • Javascript Dom元素獲取和添加詳解

    Javascript Dom元素獲取和添加詳解

    這篇文章主要介紹了Javascript Dom元素獲取和添加詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • 微信小程序中data-key屬性之數(shù)據(jù)傳輸(經(jīng)驗總結)

    微信小程序中data-key屬性之數(shù)據(jù)傳輸(經(jīng)驗總結)

    這篇文章主要介紹了微信小程序中data-key屬性:數(shù)據(jù)傳輸,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • ES6的一些實用高級技巧總結

    ES6的一些實用高級技巧總結

    ES6不僅在語法上有很大的改進,在代碼的組織結構上也有重大升級,下面這篇文章主要給大家介紹了關于ES6的一些實用高級技巧的相關資料,需要的朋友可以參考下
    2023-12-12
  • JS實現(xiàn)下拉菜單列表與登錄注冊彈窗效果

    JS實現(xiàn)下拉菜單列表與登錄注冊彈窗效果

    下面小編就為大家?guī)硪黄狫S實現(xiàn)下拉菜單列表與登錄注冊彈窗效果。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • List the UTC Time on a Computer

    List the UTC Time on a Computer

    List the UTC Time on a Computer...
    2007-06-06
  • js以分隔符分隔數(shù)組中的元素并轉換為字符串的方法

    js以分隔符分隔數(shù)組中的元素并轉換為字符串的方法

    下面小編就為大家?guī)硪黄猨s以分隔符分隔數(shù)組中的元素并轉換為字符串的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • Javascript 數(shù)組添加 shuffle 方法的實現(xiàn)代碼

    Javascript 數(shù)組添加 shuffle 方法的實現(xiàn)代碼

    PHP 里面有個非常方便的打亂數(shù)組的函數(shù) shuffle() ,這個功能在許多情況下都會用到,但 javascript 的數(shù)組卻沒有這個方法,沒有不要緊,可以擴展一個,自己動手,豐衣足食嘛。
    2009-09-09

最新評論