tabBar組件

一. 全局配置

  • 我們可以通過對項目根目錄下的app.json文件實現(xiàn)對微信小程序的全局配置粘优,該文件的內(nèi)容是一個Json對象啡氢。詳見:微信小程序官方文檔孩等。

    apps.png

  • tabBar是小程序客戶端底部或頂部tab欄的實現(xiàn)斥赋。

二. tabBar相關(guān)屬性

1. list
  • list是一個長度為2-5的數(shù)組璃哟,它定義了tab 的列表氛琢,也就是說至少必須有2 個、至多可以有 5 個 tab随闪。包含一下4個屬性:
  • pagePath: 即頁面的路徑阳似,需要在pages中先定義。
  • text: tab上按鈕文字铐伴。
  • iconPath: 圖片路徑撮奏,icon 大小限制為 40kb,建議尺寸為 81px * 81px当宴,不支持網(wǎng)絡(luò)圖片畜吊。
    當 position 為 top 時,不顯示 icon户矢。
  • selectedIconPath: 選中時的圖片路徑玲献,icon 大小限制為 40kb,建議尺寸為 81px * 81px,不支持網(wǎng)絡(luò)圖片捌年。當 position 為 top 時瓢娜,不顯示 icon。
  • 參考配置 (app.json):
    "list": [{
      "pagePath": "pages/index/index",
      "text": "主頁",
      "iconPath": "resource/tabBar/home.png",
      "selectedIconPath": "resource/tabBar/home-1.png"
    },
    {
      "pagePath": "pages/1-Icon/test",
      "text": "菜單",
      "iconPath": "resource/tabBar/menu.png",
      "selectedIconPath": "resource/tabBar/menu-1.png"
    },
    {
      "pagePath": "pages/index/index",
      "text": "購物車",
      "iconPath": "resource/tabBar/car.png",
      "selectedIconPath": "resource/tabBar/car-1.png"
    },
    {
      "pagePath": "pages/index/index",
      "text": "我的",
      "iconPath": "resource/tabBar/mine.png",
      "selectedIconPath": "resource/tabBar/mine-1.png"
    }]
2. color
  • tab 上的文字默認顏色礼预,僅支持十六進制顏色
    "color": "#dbdbdb",
3. selectedColor
  • tab 上的文字選中時的顏色眠砾,僅支持十六進制顏色
    "selectedColor": "#1296db",
4. backgroundColor
  • tab 的背景色,僅支持十六進制顏色
    "backgroundColor": "#ffffff",
5. borderStyle
  • tabbar 上邊框的顏色托酸, 默認值是: black褒颈,僅支持 black / white。
   "borderStyle": "black",    //  black / white
6. position
  • tabBar 的位置获高,默認值是: bottom哈肖,僅支持 bottom / top。
  • 注意:當position屬性被設(shè)置為頂部top時念秧,只顯示文本不顯示icon淤井。
   "position": "bottom",    //  bottom / top
7. custom
  • 此外,小程序還支持自定義tabBar來滿足更多個性化的場景摊趾,可以通過custom屬性的定義配合自定義組件來實現(xiàn)币狠。詳見官方文檔: 自定義tabBar

  • 示例配置:

{
  "tabBar": {
    "custom": true,
    "color": "#000000",
    "selectedColor": "#000000",
    "backgroundColor": "#000000",
    "list": [{
      "pagePath": "page/component/index",
      "text": "組件"
    }, 
    {
      "pagePath": "page/API/index",
      "text": "接口"
    }]
  },
  "usingComponents": {}    // 所有tab頁的json里需聲明usingComponents項砾层,也可以在app.json中全局開啟
}

三. 實現(xiàn)步驟

  • 在根目錄下新建resource/icon文件夾漩绵,把從網(wǎng)上找來的icon放在此目錄下。icon可以從阿里巴巴或谷歌的矢量圖標庫尋找: 阿里巴巴矢量圖標庫肛炮。
  • 根據(jù)實際需求在根目錄下 app.json 文件中實現(xiàn)對 tabBar 的配置止吐。
  • 實現(xiàn)具體的配置頁面。
  • app.json:
{
  "pages": [
    "pages/1-Icon/test",
    "pages/index/index",
    "pages/userConsole/userConsole",
    "pages/storageConsole/storageConsole",
    "pages/databaseGuide/databaseGuide",
    "pages/addFunction/addFunction",
    "pages/deployFunctions/deployFunctions",
    "pages/chooseLib/chooseLib",
    "pages/openapi/openapi",
    "pages/openapi/serverapi/serverapi",
    "pages/openapi/callback/callback",
    "pages/openapi/cloudid/cloudid",
    "pages/im/im",
    "pages/im/room/room"
  ],
  "tabBar": {
    "color": "#dbdbdb",
    "selectedColor": "#1296db",
    "backgroundColor": "#ffffff",
    "borderStyle": "black",
    "position": "bottom",
    "list": [{
      "pagePath": "pages/index/index",
      "text": "主頁",
      "iconPath": "resource/tabBar/home.png",
      "selectedIconPath": "resource/tabBar/home-1.png"
    },
    {
      "pagePath": "pages/1-Icon/test",
      "text": "菜單",
      "iconPath": "resource/tabBar/menu.png",
      "selectedIconPath": "resource/tabBar/menu-1.png"
    },
    {
      "pagePath": "pages/index/index",
      "text": "購物車",
      "iconPath": "resource/tabBar/car.png",
      "selectedIconPath": "resource/tabBar/car-1.png"
    },
    {
      "pagePath": "pages/index/index",
      "text": "我的",
      "iconPath": "resource/tabBar/mine.png",
      "selectedIconPath": "resource/tabBar/mine-1.png"
    }]
  },
  "window": {
    "backgroundColor": "#F6F6F6",
    "backgroundTextStyle": "light",
    "navigationBarBackgroundColor": "#F6F6F6",
    "navigationBarTitleText": "云開發(fā) QuickStart",
    "navigationBarTextStyle": "black"
  },
  "sitemapLocation": "sitemap.json",
  "style": "v2"
}

四. 效果

effect.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末侨糟,一起剝皮案震驚了整個濱河市碍扔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌秕重,老刑警劉巖不同,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異溶耘,居然都是意外死亡二拐,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進店門凳兵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來百新,“玉大人,你說我怎么就攤上這事庐扫∫魉铮” “怎么了澜倦?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵聚蝶,是天一觀的道長杰妓。 經(jīng)常有香客問我,道長碘勉,這世上最難降的妖魔是什么巷挥? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮验靡,結(jié)果婚禮上倍宾,老公的妹妹穿的比我還像新娘。我一直安慰自己胜嗓,他們只是感情好高职,可當我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著辞州,像睡著了一般怔锌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上变过,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天埃元,我揣著相機與錄音,去河邊找鬼媚狰。 笑死岛杀,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的崭孤。 我是一名探鬼主播类嗤,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼辨宠!你這毒婦竟也來了遗锣?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤彭羹,失蹤者是張志新(化名)和其女友劉穎黄伊,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體派殷,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡还最,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了毡惜。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拓轻。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖经伙,靈堂內(nèi)的尸體忽然破棺而出扶叉,到底是詐尸還是另有隱情勿锅,我是刑警寧澤派歌,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布飞醉,位于F島的核電站澈蚌,受9級特大地震影響葫笼,放射性物質(zhì)發(fā)生泄漏悬垃。R本人自食惡果不足惜昵观,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一鹃两、第九天 我趴在偏房一處隱蔽的房頂上張望意推。 院中可真熱鬧酪劫,春花似錦吞鸭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至滩字,卻和暖如春造虏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背踢械。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工酗电, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人内列。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓撵术,卻偏偏與公主長得像,于是被迫代替她去往敵國和親话瞧。 傳聞我的和親對象是個殘疾皇子嫩与,可洞房花燭夜當晚...
    茶點故事閱讀 43,566評論 2 349