微信小程序動(dòng)態(tài)tabBar實(shí)現(xiàn)

最近做項(xiàng)目的時(shí)候,突然來了個(gè)小特殊的需求崖疤,根據(jù)客戶的類型來動(dòng)態(tài)顯示底部的tabBar菜單嗜闻。當(dāng)時(shí)我就有點(diǎn)小懵逼了蜕依,這個(gè)不是小程序自帶的組件么?還要做成動(dòng)態(tài)琉雳?這就有點(diǎn)尷尬了.....
不過也只是一時(shí)尷尬而已样眠,然后我就展開了搜索之旅.....然后發(fā)現(xiàn),官方的組件確實(shí)沒辦法做動(dòng)態(tài)翠肘,那咋辦檐束,如果真的有這個(gè)需求那也是得去處理滴呀~然后也看了有一些做到這效果的方法,那就試一下唄束倍。被丧。其實(shí)就是自定義個(gè)tabBar的模板,以下是實(shí)現(xiàn):

首先绪妹,既然是說自定義組件甥桂,那是用到template了。那先在Page里新建個(gè)template的文件夾邮旷,以便放tabBar的組件黄选。

TIM圖片20171128141629.png

然后新建個(gè)tabBar.wxml文件,這里就寫下你的tabBar的結(jié)構(gòu)廊移。


<template name="tabBar">    
  <view class="tab-bar" style="color: {{tabBar.color}}; background: {{tarBar.backgroundColor}}; {{tabBar.position=='top'? 'top: 0' : 'bottom: 0'}}; {{tabBar.borderStyle? (tabBar.position=='top'? 'border-bottom: solid 1px '+tabBar.borderStyle + ';' : 'border-top: solid 1px '+tabBar.borderStyle + ';') : ''}}">    
  <block wx:for="{{tabBar.list}}" wx:key="pagePath">    
    <navigator url="{{item.pagePath}}" open-type="redirect" class="{{item.clas}}" style="{{item.active? 'color: '+(item.selectedColor? item.selectedColor : tabBar.selectedColor) : ''}}">    
      <image src="{{item.selectedIconPath}}" wx:if="{{item.active}}" class="img"></image>    
      <image src="{{item.iconPath}}" wx:if="{{!item.active}}" class="img"></image>  
      <text class='tabbar_text'>{{item.text}}</text>    
    </navigator>    
    </block>  
    <view class="clear"></view>    
  </view>    
</template>

下面是tabBar所需要用到的樣式糕簿,我這里就直接寫在全局app.wxss了。

.menu-item{  
  width: 32%;  
  float: left;  
  text-align: center;  
  padding-top: 8px;  
}  
.menu-item2{  
  width: 24%;  
  float: left;  
  text-align: center;  
  padding-top: 8px;  
}  
.img{  
  width: 30rpx;  
  height: 30rpx;  
  display: block;  
  margin:auto;  
}  
.clear{  
  clear: both;  
}  
.tab-bar{  
  position: fixed;  
  width: 100%;  
  padding: 0px 2%;  
}  
.tabbar_text{
  font-size: 28rpx
}

然后接下來是js的部分狡孔,由于是底部的導(dǎo)航,那肯定是不止一個(gè)頁(yè)面用到的蜂嗽,那這里就可以寫在全局的app.js里面方便使用苗膝。這里我寫了兩種tabBar的模板,分別對(duì)應(yīng)來顯示

//app.js
App({
  onLaunch: function () {
    // // 展示本地存儲(chǔ)能力
    // var logs = wx.getStorageSync('logs') || []
    // logs.unshift(Date.now())
    // wx.setStorageSync('logs', logs)

  },
  //第一種狀態(tài)的底部  
  editTabBar: function () {
    var _curPageArr = getCurrentPages();
    var _curPage = _curPageArr[_curPageArr.length - 1];
    var _pagePath = _curPage.__route__;
    if (_pagePath.indexOf('/') != 0) {
      _pagePath = '/' + _pagePath;
    }
    var tabBar = this.globalData.tabBar;
    for (var i = 0; i < tabBar.list.length; i++) {
      tabBar.list[i].active = false;
      if (tabBar.list[i].pagePath == _pagePath) {
        tabBar.list[i].active = true;//根據(jù)頁(yè)面地址設(shè)置當(dāng)前頁(yè)面狀態(tài)    
      }
    }
    _curPage.setData({
      tabBar: tabBar
    });
  },
  //第二種狀態(tài)的底部  
  editTabBar2: function () {
    var _curPageArr = getCurrentPages();
    var _curPage = _curPageArr[_curPageArr.length - 1];
    var _pagePath = _curPage.__route__;
    if (_pagePath.indexOf('/') != 0) {
      _pagePath = '/' + _pagePath;
    }
    var tabBar = this.globalData.tabBar2;
    for (var i = 0; i < tabBar.list.length; i++) {
      tabBar.list[i].active = false;
      if (tabBar.list[i].pagePath == _pagePath) {
        tabBar.list[i].active = true;//根據(jù)頁(yè)面地址設(shè)置當(dāng)前頁(yè)面狀態(tài)    
      }
    }
    _curPage.setData({
      tabBar: tabBar
    });
  },  
  globalData: {
    userInfo: null,
    pop:2,
    num:0,
    tabBar: {
      "color": "#9E9E9E",
      "selectedColor": "#f00",
      "backgroundColor": "#fff",
      "borderStyle": "#ccc",
      "list": [
        {
          "pagePath": "/pages/index/index",
          "text": "首頁(yè)",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "clas": "menu-item",
          "selectedColor": "#4665f9",
          active: true
        },
        {
          "pagePath": "/pages/log/index",
          "text": "日志",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item",
          active: false
        },
        {
          "pagePath": "/pages/my/index",
          "text": "我的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item",
          active: false
        }
      ],
      "position": "bottom"
    },
    tabBar2: {
      "color": "#9E9E9E",
      "selectedColor": "#f00",
      "backgroundColor": "#fff",
      "borderStyle": "#ccc",
      "list": [
        {
          "pagePath": "/pages/index/index",
          "text": "首頁(yè)",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "clas": "menu-item2",
          "selectedColor": "#4665f9",
          active: true
        },
        {
          "pagePath": "/pages/log/index",
          "text": "日志",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        },
        {
          "pagePath": "/pages/my/index",
          "text": "我的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        },
        {
          "pagePath": "/pages/new/index",
          "text": "新的",
          "iconPath": "/img/home.png",
          "selectedIconPath": "/img/home_on.png",
          "selectedColor": "#4665f9",
          "clas": "menu-item2",
          active: false
        }
      ],
      "position": "bottom"
    }
  }
})

然后在需要用到這個(gè)組件的頁(yè)面上直接調(diào)用植旧。比如這里的index頁(yè)面辱揭。

<!--index.wxml-->
<import src="../template/tabbar.wxml"/>
首頁(yè)
<template is="tabBar" data="{{tabBar:tabBar}}"></template>

image.png

然后去index.js里面調(diào)用tabBar


image.png

然后下面是效果圖。


image.png

就這些病附。我個(gè)人覺得這個(gè)自定義導(dǎo)航的用戶體驗(yàn)不是很好问窃,能不用就不要用,不過知道下方法也是ok滴完沪!如有發(fā)現(xiàn)有錯(cuò)或者不足的地方可以指出域庇,謝謝嵌戈!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市听皿,隨后出現(xiàn)的幾起案子熟呛,更是在濱河造成了極大的恐慌,老刑警劉巖尉姨,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件庵朝,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡又厉,警方通過查閱死者的電腦和手機(jī)九府,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來覆致,“玉大人侄旬,你說我怎么就攤上這事∨穸洌” “怎么了勾怒?”我有些...
    開封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)声旺。 經(jīng)常有香客問我笔链,道長(zhǎng),這世上最難降的妖魔是什么腮猖? 我笑而不...
    開封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任鉴扫,我火速辦了婚禮,結(jié)果婚禮上澈缺,老公的妹妹穿的比我還像新娘坪创。我一直安慰自己,他們只是感情好姐赡,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開白布莱预。 她就那樣靜靜地躺著,像睡著了一般项滑。 火紅的嫁衣襯著肌膚如雪依沮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天枪狂,我揣著相機(jī)與錄音危喉,去河邊找鬼。 笑死州疾,一個(gè)胖子當(dāng)著我的面吹牛辜限,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播严蓖,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼薄嫡,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼氧急!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起岂座,我...
    開封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤态蒂,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后费什,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钾恢,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年鸳址,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瘩蚪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稿黍,死狀恐怖疹瘦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巡球,我是刑警寧澤言沐,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站酣栈,受9級(jí)特大地震影響险胰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜矿筝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一起便、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧窖维,春花似錦榆综、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至琳轿,卻和暖如春陋守,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背利赋。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留猩系,地道東北人媚送。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像寇甸,于是被迫代替她去往敵國(guó)和親塘偎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子疗涉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,501評(píng)論 25 707
  • WXML WXML(WeiXin Markup Language)是微信的一套標(biāo)簽語(yǔ)言,結(jié)合基礎(chǔ)組件吟秩、事件系統(tǒng)咱扣,可...
    許劍鋒閱讀 6,774評(píng)論 3 51
  • 昨天看了一下微信小程序官方文檔,總結(jié)一下自己學(xué)習(xí)的個(gè)人心得. 首先從官方文檔給的框架說起,微信小程序官方文檔給出了...
    Mr大大大閱讀 47,139評(píng)論 9 68
  • 文/梓星 深夜 我看見一只蝴蝶 漸漸干癟的軀體 它終究會(huì)成為美麗的標(biāo)本 卻再也無法在春天里 為花朵兒跳一支舞 清晨...
    梓莘閱讀 268評(píng)論 7 8
  • 安裝ionic/Install Ionic 首先您需要安裝Node.js. 其次, 安裝最新版本的cordova ...
    發(fā)發(fā)呆喲閱讀 272評(píng)論 0 0