国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

小程序自定義導(dǎo)航自適應(yīng)組件

這篇具有很好參考價(jià)值的文章主要介紹了小程序自定義導(dǎo)航自適應(yīng)組件。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

1. 前言

小程序開發(fā)中,有時(shí)我們不需要自帶的導(dǎo)航欄,那就需要自己寫一個(gè)這樣的導(dǎo)航欄。

2. 效果展示

小程序自定義導(dǎo)航自適應(yīng)組件,小程序

3.文件目錄結(jié)構(gòu)

├── root
    │   ├── components
    │   │   └── navbar
    │   │       ├── index.js
    │   │       ├── index.wxml
    │   │       ├── index.json
    │   │       ├── index.wxss
    │   ├──pages
    │   │       ├── index.js
    │   │       ├── index.wxml
    │   │       ├── index.json
    │   │       ├── index.wxss
    └──── app.js

4.如何使用

pages/index

<navbar navbar-data="{{navbarData}}"></navbar>

Page({
  data: {
    navbarData: {
      showCapsule: 1, //是否顯示頭部左上角小房子 1顯示 0 不顯示
      showBack: 1, //是否顯示返回 1顯示 0不顯示
      // showColor: 0, //navbar背景顏色 1展示 0不展示
      // navigationBarColor: 'yellow',
      bgTransparent: true, // 時(shí)候否透明
      iconColor: 'black',
      titleColor: 'black',
      title: '首頁(yè)'
    },
  },
})

5. 實(shí)現(xiàn)代碼

需要現(xiàn)在app.js啟動(dòng)的時(shí)候獲取一些信息
app.js

// app.js
App({
  onLaunch() {
    const { statusBarHeight, titleBarHeight } = getStatusBarHeight()
    console.log(statusBarHeight, titleBarHeight)
    this.globalData.statusBarHeight = statusBarHeight;
    this.globalData.titleBarHeight = titleBarHeight;
  },
  globalData: {
    statusBarHeight: "",
    titleBarHeight: ""
  }
})
function getStatusBarHeight() {
  let res = wx.getSystemInfoSync()
  let customTitleBarHeight;
  try {
    const menuInfo = wx.getMenuButtonBoundingClientRect();
    if (equalVersion(res.version, "7.0.3")) {
      customTitleBarHeight =
        menuInfo.height + (menuInfo.top - res.statusBarHeight) * 2;
    } else {
      customTitleBarHeight = menuInfo.height + menuInfo.top * 2;
    }
  } catch (e) {
    customTitleBarHeight = 48;
  }
  if (res.model.indexOf("iPhone") !== -1) {
    customTitleBarHeight = 44;
  }
  return {
    statusBarHeight: res.statusBarHeight,
    titleBarHeight: customTitleBarHeight,
  }
};

function equalVersion(curV, reqV) {
  let arr1 = curV.split(".");
  let arr2 = reqV.split(".");

  let maxL = Math.max(arr1.length, arr2.length);
  let pos = 0;
  let diff = 0;

  while (pos < maxL) {
    diff = parseInt(arr1[pos]) - parseInt(arr2[pos]);
    console.log(diff, parseInt(arr1[pos]), parseInt(arr2[pos]));
    if (diff != 0) {
      break;
    }
    pos++;
  }
  if (diff > 0 || diff == 0) {
    //新版本、穩(wěn)定版
    return 1;
  } else {
    // 舊版本
    return 0;
  }
}

下面是組件代碼
component/navbar.js

/**
 * 自定義頭部
 */

const app = getApp()

// 版本號(hào)比較函數(shù)
function compareVersion(v1, v2) {
    v1 = v1.split('.')
    v2 = v2.split('.')
    const len = Math.max(v1.length, v2.length)
    while (v1.length < len) {
        v1.push('0')
    }
    while (v2.length < len) {
        v2.push('0')
    }
    for (let i = 0; i < len; i++) {
        const num1 = parseInt(v1[i])
        const num2 = parseInt(v2[i])
        if (num1 > num2) {
            return 1
        } else if (num1 < num2) {
            return -1
        }
    }
    return 0
}


Component({
    properties: {
        navbarData: { //navbarData   由父頁(yè)面?zhèn)鬟f的數(shù)據(jù),變量名字自命名
            type: Object,
            value: {},
            observer: function (newVal, oldVal, changedPath) {
                if (newVal == null && typeof (oldVal) == 'object') {
                    try {
                        var _o = {};
                        var defaultData = {
                            statusBarHeight: '',
                            titleBarHeight: '',
                            navbarData: {
                                showCapsule: 1, //是否顯示左上角小房子 1顯示 0 不顯示
                                showBack: 1, //是否顯示返回 1顯示 0不顯示
                                showColor: 1, //navbar背景顏色 1藍(lán)色 0白色
                                navigationBarColor: '#ffffff',
                                bgTransparent: false, // true 背景為透明 false 不透明(下面兩個(gè)屬性也不生效)
                                iconColor: 'black', // white 左側(cè)icon顏色
                                titleColor: '#000000' // 可以指定title具體色值
                            }
                        }

                        _o['navibarData'] = defaultData['navbarData']
                        this.setData(_o);
                    } catch (e) {

                    }
                } else {
                    // var data = this.data;
                    var data = {};
                    var path = 'navibarData';
                    Object.keys(newVal).forEach(key => {
                        data[`${path}.${key}`] = newVal[key];
                    })
                    this.setData(data);
                }
            }
        }
    },

    data: {
        statusBarHeight: '',
        titleBarHeight: '',
        showNavbar: '',
        menuButtonInfo: {},
        navibarData: {
            showCapsule: 0, //是否顯示左上角小房子
            showBack: 1, //是否顯示返回
            showColor: 1, //navbar背景顏色,
            navigationBarColor: '#ffffff',
            bgTransparent: false, // true 背景為透明 false 不透明(下面兩個(gè)屬性也不生效)
            iconColor: 'black', // white 左側(cè)icon顏色
            titleColor: '#000000' // 可以指定title具體色值
        }
    },
    attached: function () {
        if (wx.getSystemInfoSync().platform.toLowerCase().indexOf('devtools') != -1) {
            this.setData({
                showNavbar: true
            });
        } else {
            // 獲取版本號(hào)
            const version = wx.getSystemInfoSync().version
            if (compareVersion(version, '7.0.0') >= 0) {
                // 版本號(hào)大于7.0.0時(shí),顯示自定義頭部
                this.setData({
                    showNavbar: true
                })
            } else {
                //   // 版本號(hào)低于7.0.0時(shí),隱藏自定義頭部
                this.setData({
                    showNavbar: false
                })
            }
        }
        this.setData({
            statusBarHeight: app.globalData.statusBarHeight,
            titleBarHeight: app.globalData.titleBarHeight
        });
        //獲取右上角膠囊的大小,為顯示自定義icon做準(zhǔn)備
        this.setData({
            menuButtonInfo: wx.getMenuButtonBoundingClientRect()
        });
    },
    ready() {
        try {
            const currentPages = getCurrentPages()
            const _o1 = {}
            //無(wú)論如何返回按鈕出現(xiàn)的規(guī)則不變
            if (currentPages.length > 1) {
                _o1.showBack = true;
            } else {
                _o1.showBack = false;
            }
            this.setData({
                navibarData: {
                    ...this.data.navibarData,
                    ..._o1
                }
            })
        } catch (e) {

        }
    },
    methods: {
        //返回到首頁(yè)
        _backhome(e) {
            wx.switchTab({
                url: '/pages/home/homepage',
            });
        },
        _backlast(e) {
            wx.navigateBack();
        },
    },
})

component/navbar.wxml

<view style="padding-top:{{navibarData.bgTransparent ? 0 : (statusBarHeight+titleBarHeight)}}px" wx:if='{{showNavbar}}'>
  <view wx:if='{{navibarData.bgTransparent}}' class="nav-wrap b-nav-wrap transparent-bg">
    <template is="titleBarContent" data="{{statusBarHeight,titleBarHeight,navibarData,menuButtonInfo}}"/>
  </view>
  <block wx:else>
    <view wx:if='{{navibarData.showColor}}' class="nav-wrap" style='background-color:{{navibarData && navibarData.navigationBarColor}};'>
      <template is="titleBarContent" data="{{statusBarHeight,titleBarHeight,navibarData,menuButtonInfo}}"/>
    </view>
    <view wx:else class="nav-wrap b-nav-wrap">
      <template is="titleBarContent" data="{{statusBarHeight,titleBarHeight,navibarData,menuButtonInfo}}"/>
    </view>  
  </block>
</view>

<template name="titleBarContent">
  <view class="status-bar" style="height:{{statusBarHeight}}px"></view>
    <view class="title-bar" style="height:{{titleBarHeight}}px">
      <view class="title-bar-group {{navibarData.showBack ^ navibarData.showCapsule ? 'only-group-icon' : navibarData.showBack && navibarData.showCapsule ? '' :'no-group-icon'}}">
        <view class="title-bar-icon" bindtap='_backlast' wx:if='{{navibarData.showBack}}'>
          <image wx:if="{{navibarData.bgTransparent&&navibarData.iconColor == 'white'}}" src='' mode='aspectFit' class='back-home-return'></image>
          <image wx:else src='' mode='aspectFit' class='back-home-return'></image>
        </view>
        <view class="line" wx:if='{{navibarData.showBack && navibarData.showCapsule}}'></view>
        <view class="title-bar-icon" bindtap='_backhome' wx:if='{{navibarData.showCapsule}}'>
          <image wx:if="{{navibarData.bgTransparent&&navibarData.iconColor == 'white'}}" src='' mode='aspectFit' class='back-home'></image>
          <image wx:else src='' mode='aspectFit' class='back-home'></image>
        </view>
      </view>
      <view style="flex-grow:1;height:100%;background-color: transparent; display: flex; justify-content:{{navibarData.iconData.align?(navibarData.iconData.align==='right'?'flex-end':'flex-start'):'flex-start'}};">
      <view style="display: flex;align-items: center;height: 100%;">
      </view>
      </view>
      <view style="width:{{menuButtonInfo.width}}px;height:100%;background-color: transparent;"></view> 
      <view class='nav-titleContainer'>
        <view wx:if="{{navibarData.bgTransparent}}" class="nav-title" style="color:{{navibarData.titleColor}}">{{navibarData.title}}</view>
        <view wx:else class="nav-title">{{navibarData.title}}</view>
      </view>
    </view>
</template>

component/navbar.wxss

/* 頂部要固定定位 */
.nav-wrap {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 99;
  background: #ffffff;
}
/* 標(biāo)題要居中 */
.nav-titleContainer {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  position: absolute;
  top:0;
  left:0;
  height: 100%;
  width: 100%;
  pointer-events: none;
}
.nav-title {
  margin: 0 180rpx;
  text-align: center;
  /* width: 50%; */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 36rpx;
  color: #000000;
  font-weight: 600;
  z-index: -1;
}

.back-home {
  width: 40rpx;
  height: 40rpx;
  cursor: pointer;
}
.back-home-return {
  width: 40rpx;
  height: 40rpx;
  cursor: pointer;
}

.title-bar-group {
  border: 1rpx solid rgba(255,255,255,0.25);
  background: rgba(0,0,0,0.12);
  border-radius: 32rpx;
  display: flex;
  height: 64rpx;
  width: 174rpx;
  box-sizing: border-box;
  align-items:center;
  overflow: hidden;
}

.title-bar-group.only-group-icon {
  border: none;
  background: transparent;
  width: 87rpx;
}

.title-bar-group.no-group-icon {
  border: none;
  background: transparent;
  width: 0rpx;
}

.title-bar-group.no-group-icon + .nav-titleContainer {
  justify-content:flex-start;
}

.title-bar-group.no-group-icon + .nav-titleContainer .nav-title {
  margin: 0 180rpx 0 12rpx;
  text-align:left;
}

.title-bar-icon {
  flex: auto;
  display:flex;
  align-items:center;
  justify-content:center;
  height:100%;
}

.line{
  height: 38rpx;
  border-left: 1px solid rgba(255,255,255,0.12);
}

.title-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 20rpx;
  position: relative;
}

.b-nav-wrap.nav-wrap {
  background: #fff;
}
.b-nav-wrap .nav-title {
  color: #111;
}
.b-nav-wrap .title-bar-group {
  border: 1rpx solid rgba(0,0,0,0.12);
  background: #ffffff;
}
.b-nav-wrap .line{
  border-left: 1px solid rgba(0,0,0,0.12);
}

.b-nav-wrap .title-bar-group.only-group-icon {
  border: none;
  background: transparent;
  width: 87rpx;
}

.b-nav-wrap .title-bar-group.no-group-icon {
  border: none;
  background: transparent;
  width: 0rpx;
}

.b-nav-wrap.nav-wrap.transparent-bg,
.b-nav-wrap.nav-wrap.transparent-bg .title-bar-group {
  background: transparent;
}

6. 原理分析

小程序自定義導(dǎo)航自適應(yīng)組件,小程序

wx.getSystemInfoSync(); // 獲取到狀態(tài)欄的信息
wx.getMenuButtonBoundingClientRect(); // 獲取膠囊的信息文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-802426.html

function getStatusBarHeight() {
  let res = wx.getSystemInfoSync()
  let customTitleBarHeight;
  try {
    const menuInfo = wx.getMenuButtonBoundingClientRect(); // 獲取膠囊的信息
    if (equalVersion(res.version, "7.0.3")) {
      customTitleBarHeight =
        menuInfo.height + (menuInfo.top - res.statusBarHeight) * 2;
    } else {
      customTitleBarHeight = menuInfo.height + menuInfo.top * 2;
    }
  } catch (e) {
    customTitleBarHeight = 48;
  }
  if (res.model.indexOf("iPhone") !== -1) {
    customTitleBarHeight = 44;
  }
  return {
    statusBarHeight: res.statusBarHeight, // 狀態(tài)欄的高度
    titleBarHeight: customTitleBarHeight, // title的高度
  }
};

到了這里,關(guān)于小程序自定義導(dǎo)航自適應(yīng)組件的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 記錄一下小程序自定義導(dǎo)航欄消息未讀已讀小紅點(diǎn),以及分組件的消息數(shù)量數(shù)據(jù)實(shí)時(shí)讀取

    本案例,Message 身為組件,使用不了任何鉤子來(lái)重新獲取 this.getMessageList() 消息列表 使用 props 父子傳參,因?yàn)?Message 組件使用不了頁(yè)面生命周期從而無(wú)法拿到傳遞過(guò)來(lái)的數(shù)據(jù) 使用 watch 監(jiān)聽不到 props 更不建議使用本地存儲(chǔ),那樣和 props 結(jié)果差不多 案例中采用的是發(fā)送全局事

    2024年04月10日
    瀏覽(13)
  • 簡(jiǎn)潔簡(jiǎn)約個(gè)人導(dǎo)航頁(yè)引導(dǎo)源碼PC手機(jī)自適應(yīng)模板自定義背景以及音樂帶后臺(tái)包學(xué)會(huì)搜索引擎可收錄

    簡(jiǎn)潔簡(jiǎn)約個(gè)人導(dǎo)航頁(yè)引導(dǎo)源碼PC手機(jī)自適應(yīng)模板自定義背景以及音樂帶后臺(tái)包學(xué)會(huì)搜索引擎可收錄

    簡(jiǎn)潔簡(jiǎn)約個(gè)人導(dǎo)航頁(yè)引導(dǎo)源碼PC手機(jī)自適應(yīng)模板自定義背景以及音樂帶后臺(tái)包學(xué)會(huì) 搜索引擎可收錄 ? ? ? 獲取源碼:https://pan.baidu.com/s/1gbnBmL35RhzGuZ5P0Mk7tA?pwd=h06o 提取碼:h06o ?

    2024年02月07日
    瀏覽(51)
  • [自定義 Vue 組件] 小尾巴頂部導(dǎo)航欄(2.0) TailTopNav

    [自定義 Vue 組件] 小尾巴頂部導(dǎo)航欄(2.0) TailTopNav

    文章歸檔:https://www.yuque.com/u27599042/coding_star/oglrqteg8fzvvzn0 [自定義 Vue 組件] 響應(yīng)式頂部導(dǎo)航欄(1.0) TopNav:https://www.yuque.com/u27599042/coding_star/hzltsltxgavwx8u2 [自定義 Vue 組件] 小尾巴 Logo 組件(2.0) TailLogo:https://www.yuque.com/u27599042/coding_star/mluie83zdzaf40sy [自定義 Vue 組件] 小尾巴下拉菜

    2024年02月05日
    瀏覽(44)
  • 小程序?qū)Ш酱┩盖易远x導(dǎo)航欄

    小程序?qū)Ш酱┩盖易远x導(dǎo)航欄

    需求 實(shí)現(xiàn)小程序隱藏頭部導(dǎo)航欄,且導(dǎo)航欄穿透無(wú)高度,并且要定義返回事件 在 app.json 里面把 “navigationStyle” 設(shè)置為 “custom” 這樣子之后頁(yè)面就只會(huì)保留右上角膠囊按鈕。

    2024年02月16日
    瀏覽(14)
  • 小程序自定義導(dǎo)航欄

    小程序自定義導(dǎo)航欄

    app.json文件下 app.js文件 組件文件components文件夾下新增navBar文件 index.js index.wxss index.wxml 使用 js

    2024年02月16日
    瀏覽(18)
  • 微信小程序自定義頂部導(dǎo)航,滾動(dòng)頁(yè)面頂部導(dǎo)航顏色漸變

    微信小程序自定義頂部導(dǎo)航,滾動(dòng)頁(yè)面頂部導(dǎo)航顏色漸變

    微信小程序自定義頂部導(dǎo)航欄,使背景圖置頂;當(dāng)向上滾動(dòng)頁(yè)面時(shí),實(shí)現(xiàn)頂部導(dǎo)航顏色漸變 實(shí)現(xiàn)方法 代碼如下(示例): 提示:由于不同的手機(jī)機(jī)型頂部導(dǎo)航高度不一樣,所有要獲取手機(jī)的信息 總共三步: 1、初始化獲取頂部導(dǎo)航信息 2、頂部導(dǎo)航文字上方通過(guò)view占位,同

    2024年02月11日
    瀏覽(27)
  • uniapp小程序自定義頭部導(dǎo)航

    uniapp小程序自定義頭部導(dǎo)航

    我們?cè)陂_發(fā)小程序時(shí),自帶的頭部導(dǎo)航樣式往往不能滿足需求,故只能自定義導(dǎo)航,接下來(lái)簡(jiǎn)要介紹下如何實(shí)現(xiàn): 1.?去除自帶的頭部導(dǎo)航 要想自定義頭部導(dǎo)航,首先要到pages.json文件夾中,找到對(duì)應(yīng)頁(yè)面,然后在style中寫上代碼: 2.封裝自定義的頭部導(dǎo)航 一個(gè)小程序,可能會(huì)

    2024年02月11日
    瀏覽(20)
  • Uniapp-小程序自定義導(dǎo)航欄

    Uniapp-小程序自定義導(dǎo)航欄

    制作小程序頁(yè)面時(shí)候發(fā)現(xiàn)原生導(dǎo)航欄有一定的高度是沒有背景渲染的會(huì)出現(xiàn)這種情況 但是我們需要的是 小程序的原生導(dǎo)航欄存在。一般可以使用?純色填充頂部欄 可以直接使用navigationBarBackgroundColor完成 在style中添加?\\\"navigationBarBackgroundColor\\\": \\\"#FED000\\\" 但是業(yè)務(wù)需求需要添加自

    2024年02月05日
    瀏覽(20)
  • 微信原生小程序自定義頂部導(dǎo)航

    微信原生小程序自定義頂部導(dǎo)航

    都2023了,自定義頂部導(dǎo)航應(yīng)該不是什么新鮮事了,這里只是簡(jiǎn)單記錄下 微信自己也提供了自定義頂部導(dǎo)航 navigation-bar ,大概看了下,可配置的也不少,所以看需求了,如果簡(jiǎn)單可以采用微信提供的,老規(guī)矩,先看效果 狀態(tài)欄高度(getSystemInfoSync),就是手機(jī)頂部網(wǎng)絡(luò)那塊的

    2024年02月15日
    瀏覽(24)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包