分享一個小程式開發實戰

零下一度
發布: 2017-06-24 11:42:19
原創
1719 人瀏覽過

電商底部導覽列的製作

我想大家對電商一定不陌生,一般電商的底部導覽列有以下幾個首頁、分類、購物車、個人中心。

app.json是用來配置page路徑以及導航列屬性的,那我們要做首頁、分類、購物車、個人中心界面就要在page也添加這幾個界面,所以在app. json的page加入如下程式碼,寫入page路徑,系統會自動幫你創建介面的

  "pages":["pages/home/home","pages/classify/classify",  "pages/cart/cart","pages/mine/mine","pages/index/index"
  ],
登入後複製

好,既然加入了四個介面,那我們要怎麼做底部導覽列吶,今天給app .json再增加一個屬性,就是可以在app.json裡配置導航欄,將下面程式碼加入app.json裡面

 "tabBar": {"color": "#858585","selectedColor": "#f0145a","backgroundColor": "#ffffff","borderStyle": "#000","list": [
      {"pagePath": "pages/home/home","iconPath": "images/bottomNav/home.png","selectedIconPath": "images/bottomNav/home_select.png","text": "首页"
      },
      {"pagePath": "pages/classify/classify","iconPath": "images/bottomNav/classify.png","selectedIconPath": "images/bottomNav/classify_select.png","text": "分类"
      },
      {"pagePath": "pages/cart/cart","iconPath": "images/bottomNav/cart.png","selectedIconPath": "images/bottomNav/cart_select.png","text": "购物车"
      },
      {"pagePath": "pages/mine/mine","iconPath": "images/bottomNav/mine.png","selectedIconPath": "images/bottomNav/mine_select.png","text": "我的"
      }
    ]
  }
登入後複製

tabBar系統自帶字段,不可改,加入這個字段就是告訴系統你要新增導覽欄,color、selectedColor、backgroundColor從字面意思也字段,分別對應的屬性是預設字體顏色、勾選字體顏色、背景顏色。著重說一下borderStyle,這個的定義底部導覽列與介面的邊界線,屬性有點特殊,特殊在如果你不想要這個分界線,可以把屬性設定為white,剩下的不管你寫入的是什麼,系統都理解為要添加這條分界線,不信你可以試試。 list屬性自然是設定對應導覽列的介面啦,

  • ##pagePath:頁面路徑,就是你寫在page裡的路徑

  • iconPath :預設導覽列圖片路徑

  • selectedIconPath:勾選圖片的路徑

  • ##text:導覽列名字
  • 這裡要說的是,圖片路徑,一定要寫對,不然找不到圖片就顯示不出來,這裡給大家提供我的導航欄圖片---提取碼:8zwe 大家可以根據我的圖片路徑建立對應的資料夾,如下圖

1-1.png
需要注意的:

    #添加tabBar的時候別忘記別忘記上面有一個逗號,這個是用來區分每個屬性的,所以你每添加一個屬性都要用逗號分隔開來,這點要注意,不然會報錯,這就是我把標點去掉的錯誤日誌,一般報出錯誤日誌Expecting 'EOF' XXXXXXXXX,got STRING都是語法錯誤,所以要仔細檢查看看哪裡少寫了東西。

  • 1-2.png
  • #還有就是在.json檔案裡是不可以寫註解的,我原本想加入一點註解方便讀者閱讀,然而會出現下面錯誤訊息,解決辦法很簡單,把註解刪除就可以啦

  • 1 -3.png
    舉一反三

    1. 我們建立了四個導覽欄,那麼如果我想再增加兩個導覽列可以嗎?
    2. 你也許覺得很簡單,試著去在list列表裡加兩個了吧,我也是這麼做的,但是出問題啦。系統會報錯,這回知道了吧,最多只能是五個,沒辦法,誰讓微信是老大,人家定最多五個那就只能最多五個嘍!



      1-3.png
    3. #你不知道你有沒有註意到,導覽列預設首頁勾選為紅色,那我想要預設勾選分類為紅色吶,該怎麼辦?
    4. 這個有點難度了吧,我剛開始想的是在tabBar屬性把list裡的第一個home屬性和classify屬性換一下應該就可以解決,然而並不是這樣的,因為沒有效果,後來也是一次誤打誤撞給發現的,我給你點小提示,有沒有註意到,pages的第一個路徑是什麼pages/home/home,沒錯,就是它,如果想要分類classify作為預設的勾選項,你只需要在pages屬性把home的路徑和classify路徑換一下,保存,重新編譯一下,你要的效果就出來了,這裡可以總結的一點就是,tabBar是到page裡的第一行路徑作為默認勾選項的。


    電商頂部導覽列製作

既然講了導覽欄,乾脆今天多講解一點,接著教大家頂部導覽列怎麼製作,先上效果圖

2-1.png
#


这个导航栏可不像底部导航栏啦,因为他的级别比较低,是页面级别的导航栏,所以要写在页面里,你想要在哪个页面加入顶部导航栏就在哪个页面里添加如下代码,这里以首页的界面为例:
home.wxss

/* pages/home/home.wxss */page{  
  display: flex;  
  flex-direction: column;  
  height: 100%;  
}  
.navbar{  
  flex: none;  
  display: flex;  
  background: #fff;  
}  
.navbar .item{  
  position: relative;  
  flex: auto;  
  text-align: center;  
  line-height: 80rpx;  
  font-size:14px;
}  
/* 顶部导航字体颜色 */.navbar .item.active{  
  color: #f0145a;  
}  
/* 顶部指示条属性 */.navbar .item.active:after{  
  content: "";  
  display: block;  
  position: absolute;  
  bottom: 0;  
  left: 0;  
  right: 0;  
  height: 6rpx;  
  background: #f0145a;  
}
登入後複製

home.wxml

<!--导航条-->  
<view class="navbar">  
  <text wx:for="{{navbar}}" data-idx="{{index}}" class="item {{currentTab==index ? &#39;active&#39; : &#39;&#39;}}" wx:key="unique" bindtap="navbarTap">{{item}}</text>  
</view>
登入後複製

在home.wxml里面bindtap字段我们已经讲解过啦,是事件监听的标识符,事件名称叫“navbarTap”可以到home.js里查找到这个事件wx:for这个字段重点讲解,在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,这是官方解释,说白了就是item默认叫做变量的值,index表示第几个变量的值,还不太明白请看这个 微信 wx:for 的讲解

  • wx:for="{{navbar}}" 意思是虚幻navbar的数组数据

  • {{item}} 这里面是navbar数组里面的值,如护肤、彩妆等值

  • wx:key="unique" 来指定列表中项目的唯一的标识符

  • data-idx="{{index}}" 存储一些数据供home.js里调用,这里data-xxx,xxx就是你给home.js里提供的数据关键词,home.js通过获取xxx关键词来获取xxx里面的数据

home.js

// pages/home/home.jsvar app = getApp()
Page({  data: {navbar: [&#39;护肤&#39;, &#39;彩妆&#39;, &#39;香水&#39;,&#39;个人护理&#39;],currentTab: 0,
  },  // 导航切换监听
  navbarTap: function (e) {console.debug(e);this.setData({      currentTab: e.currentTarget.dataset.idx
    })
  },

})
登入後複製

home.js,这里读过微信小程序入门篇(二)都知道,page页面里.js一般是放data数据和事件监听的,这里data有一个navbar导航栏数据,还有一个记录当前位置的currentTab,字段可以自由命名,赋值的时候对应上就好,

  • navbarTap 记得在home.wxml里面data-idx属性吗,在这里用到,currentTab: e.currentTarget.dataset.idx 把当前用户选择的Tab传给currentTab里,为了验证一下结果,我在这里面加入了一个输出日志console.debug(e);,可以在控制台上看输出的日志,我选择点击彩妆,输出台的数据idx:1刚好是彩妆的位置。


2-2.png

总结

今天我们讲解的微信小程序的底部导航栏和顶部导航栏,导航栏应该说是必须的对于电商小程序来说,那么今天的导航栏教程你掌握了吗?

学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入学习交流群

以上是分享一個小程式開發實戰的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板