<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        小程序自定義單頁面、全局導航欄的實現代碼

        來源:懂視網 責編:小采 時間:2020-11-27 22:00:07
        文檔

        小程序自定義單頁面、全局導航欄的實現代碼

        小程序自定義單頁面、全局導航欄的實現代碼:需求 產品說小程序返回到首頁不太方便,想添加返回首頁按鈕,UI說導航欄能不能設置背景圖片,因為那樣設計挺好看的。 需求分析并制定方案 這產品和UI都提需求了,咱也不能反駁哈,所以開始調研,分析可行性方案;1、可以添加懸浮按鈕。2、自定義導航欄。 添
        推薦度:
        導讀小程序自定義單頁面、全局導航欄的實現代碼:需求 產品說小程序返回到首頁不太方便,想添加返回首頁按鈕,UI說導航欄能不能設置背景圖片,因為那樣設計挺好看的。 需求分析并制定方案 這產品和UI都提需求了,咱也不能反駁哈,所以開始調研,分析可行性方案;1、可以添加懸浮按鈕。2、自定義導航欄。 添

        二、實現的步驟

        以下說下幾個要點:

        1、自定義導航欄文本,是否顯示返回,是否顯示返回首頁,導航欄高度

        2、statusBarHeight,用來獲取手機狀態欄的高度,這個需要在全局app.js中的onLaunch,調用wx.getSystemInfo獲取,navigationBarHeight+默認的高度,這個是設定整個導航欄的高度,

        3、還有注意的,在寫樣式距離和大小時建議都用px,因小程序右邊的膠囊也是用的px,不是rpx。

        4、因為自定義導航欄每個頁面都要寫,所以把導航欄封裝了公共組件,這樣只需要在每個頁面引入即可。

        如下是封裝的導航欄組件:

        wxml

        <view class="navbar" style="{{'height: ' + navigationBarHeight}}">
         <view style="{{'height: ' + statusBarHeight}}"></view>
         <view class='title-container'>
         <view class='capsule' wx:if="{{ back || home }}">
         <view bindtap='back' wx:if="{{back}}">
         <image src='/images/back.png'></image> 
         </view>
         <view bindtap='backHome' wx:if="{{home}}">
         <image src='/images/home.png'></image>
         </view>
         </view>
         <view class='title'>{{text}}</view>
         </view>
        </view>
        <view style="{{'height: ' + navigationBarHeight}};background: white;"></view>
        這里有個需注意的問題,就是一般會出現自定義導航欄,下拉頁面,導航欄也隨著會下拉,這種問題是因為設置fixed后頁面元素整體上移了navigationBarHeight,所以在此組件里設置一個空白view元素占用最上面的navigationBarHeight這塊高度

        wxss

        .navbar {
         width: 100%;
         background-color: #1797eb;
         position: fixed;
         top: 0;
         left: 0;
         z-index: 999;
        }
        .title-container {
         height: 40px;
         display: flex;
         align-items: center;
         position: relative;
        }
        .capsule {
         margin-left: 10px;
         height: 30px;
         background: rgba(255, 255, 255, 0.6);
         border: 1px solid #fff;
         border-radius: 16px;
         display: flex;
         align-items: center;
        }
        .capsule > view {
         width: 45px;
         height: 60%;
         position: relative;
        .capsule > view:nth-child(2) {
         border-left: 1px solid #fff; 
        }
        .capsule image {
         width: 50%;
         height: 100%;
         position: absolute;
         left: 50%;
         top: 50%;
         transform: translate(-50%,-50%);
        }
        .title {
         color: white;
         position: absolute;
         top: 6px;
         left: 104px;
         right: 104px;
         height: 30px;
         line-height: 30px;
         font-size: 14px;
         text-align: center;
         overflow: hidden;
         text-overflow: ellipsis;
         white-space: nowrap;
        }

        js

        const app = getApp()
        
        Component({
        
         properties: {
         text: {
         type: String,
         value: 'Wechat'
         },
         back: {
         type: Boolean,
         value: false
         },
         home: {
         type: Boolean,
         value: false
         }
         },
         data: {
         statusBarHeight: app.globalData.statusBarHeight + 'px',
         navigationBarHeight: (app.globalData.statusBarHeight + 44) + 'px'
         },
        
         methods: {
         backHome: function () {
         let pages = getCurrentPages()
         wx.navigateBack({
         delta: pages.length
         })
         },
         back: function () {
         wx.navigateBack({
         delta: 1
         })
         }
         }
        })

        json

        {
         "component": true,
         "usingComponents": {}
        }
        
        最終還需要考慮下版本兼容的問題,畢竟還有一些用戶,微信版本并沒有更新到最新版本。

        首先可以在app.js里面獲取下當前用戶的微信版本,做下版本比較,如果小于這個版本,設置個全局變量,也可以在組件寫個方法,在不同的頁面打開顯示不同的頂部導航欄,或者可以控制是否顯示導航欄,這里就不詳細說了。

        親自試了下,在低于7.0版本的微信中,如果采用單頁面自定義導航欄,會出現兩個導航欄,這時候通過判斷版本號不要再渲染自定義的導航欄組件了,在頁面的配置文件里寫上title名,還有相應的背景色,這樣就會顯示自帶的導航欄了。

        總結

        小程序開發是有些坑的地方,從不支持自定義導航欄,到支持全局自定義導航欄,再到現在的支持單頁面配置,可以看出在慢慢完善。還有底部tabbar,可自己選擇配置的太少了,雖然也支持自定義,但是發現自定義寫的底部導航組件體驗并不好,每次打開頁面都會重新渲染底部的按鈕,如果全部寫成在一個頁面里的tab切換,雖然按鈕每次不用重新加載了,但是業務多肯定不行,寫到一個單頁面里東西也太多了。 希望微信能夠多添加或放開一些功能,讓開發者更好的服務于產品,給用戶更好的體驗。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        小程序自定義單頁面、全局導航欄的實現代碼

        小程序自定義單頁面、全局導航欄的實現代碼:需求 產品說小程序返回到首頁不太方便,想添加返回首頁按鈕,UI說導航欄能不能設置背景圖片,因為那樣設計挺好看的。 需求分析并制定方案 這產品和UI都提需求了,咱也不能反駁哈,所以開始調研,分析可行性方案;1、可以添加懸浮按鈕。2、自定義導航欄。 添
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲精品中文字幕无码AV| 亚洲色大网站WWW永久网站| 一级午夜免费视频| 国产国产成年年人免费看片| 亚洲日韩久久综合中文字幕| 免费中文熟妇在线影片| 中文字幕在线观看亚洲视频| 日韩国产免费一区二区三区| 亚洲一区二区三区在线观看蜜桃| 免费观看AV片在线播放| 亚洲精品人成网线在线播放va| 国产精品国产自线拍免费软件| 美国毛片亚洲社区在线观看| 亚洲日韩中文字幕日韩在线| 成在人线av无码免费高潮水| 亚洲A∨无码无在线观看| 2019中文字幕在线电影免费 | 日韩精品无码免费专区网站| 亚洲无码视频在线| 免费国产黄网站在线观看| 亚洲最大的视频网站| 毛片免费在线观看网址| 国产精品亚洲片在线花蝴蝶| 久久亚洲av无码精品浪潮| 一级毛片在线观看免费| 久久精品国产亚洲AV忘忧草18| 日本久久久免费高清| 一级毛片视频免费| 久久亚洲日韩看片无码| 午夜网站免费版在线观看| 国产va免费精品| 亚洲毛片免费观看| 四虎永久免费观看| 国产永久免费高清在线| 国产91在线|亚洲| 国产91精品一区二区麻豆亚洲| 久久免费精品视频| 久久精品国产亚洲Aⅴ香蕉| 免费一级毛片在线播放视频| 国产亚洲精品影视在线| 在线A亚洲老鸭窝天堂|