微信小程序自定义底部导航栏

app.json中修改 tabBar

  "tabBar": {
    "custom": true,
    "color": "#ABABAB",
    "selectedColor": "#22C992",
    "borderStyle": "white",
    "backgroundColor": "#FAF9F9",
    "list": [{
        "pagePath": "pages/tabar/index/index",
        "iconPath": "/image/index.png",
        "selectedIconPath": "/image/index1.png",
        "text": "首页"
      },
      {
        "pagePath": "pages/tabar/practice/index",
        "iconPath": "/image/practice.png",
        "selectedIconPath": "/image/practice1.png",
        "text": "劳动实践"
      },
      {
        "pagePath": "pages/tabar/manage/index",
        "iconPath": "/image/manage.png",
        "selectedIconPath": "/image/manage1.png",
        "text": "教务管理"
      },
      {
        "pagePath": "pages/tabar/mine/index",
        "iconPath": "/image/my.png",
        "selectedIconPath": "/image/my1.png",
        "text": "我的"
      }
    ]
  }
View Code

在根目录 和pages 同级别的目录创建custom-tab-bar组件

wx.ml

<view class="tab-bar">
  <view wx:for="{{list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}" data-index="{{index}}" bindtap="switchTab">
    <image src="{{selected === index ? item.selectedIconPath : item.iconPath}}"></image>
    <view style="color: {{selected === index ? selectedColor : color}}">{{item.text}}</view>
  </view>
</view>
View Code

wx.ss

.tab-bar {
  position: fixed;
  z-index: 10;
  bottom: 0;
  left: 0;
  right: 0;
  box-sizing: border-box;
  padding: 11rpx 0 40rpx;
  height: 120rpx;
  background: white;
  display: flex;
  box-shadow: 0px -6rpx 30rpx 0px rgba(0, 0, 0, 0.05);
}



.tab-bar-item {
  flex: 1;
  text-align: center;
  display: flex;
  align-items: center;
  flex-direction: column;
}

.tab-bar-item image {
  width: 48rpx;
  height: 48rpx;
  margin-bottom: 7rpx;
}

.tab-bar-item view {
  height: 20rpx;
  font-size: 20rpx;
  font-family: PingFangSC-Regular, PingFang SC;
  font-weight: 400;
  color: #A5AAAE;
  line-height: 20px;
}
View Code

 

wx.js

Component({
  data: {
    selected: 0,
    color: "#7A7E83",
    selectedColor: "#3cc51f",
    "list": [{
        "pagePath": "/pages/tabar/index/index",
        "iconPath": "/image/index.png",
        "selectedIconPath": "/image/index1.png",
        "text": "首页"
      },
      {
        "pagePath": "/pages/tabar/practice/index",
        "iconPath": "/image/practice.png",
        "selectedIconPath": "/image/practice1.png",
        "text": "劳动实践"
      },
      {
        "pagePath": "/pages/tabar/manage/index",
        "iconPath": "/image/manage.png",
        "selectedIconPath": "/image/manage1.png",
        "text": "教务管理"
      },
      {
        "pagePath": "/pages/tabar/mine/index",
        "iconPath": "/image/my.png",
        "selectedIconPath": "/image/my1.png",
        "text": "我的"
      }
    ]
  },
  attached() {},
  methods: {
    switchTab(e) {
      const data = e.currentTarget.dataset
      const url = data.path
      wx.switchTab({
        url
      })
      this.setData({
        selected: data.index
      })
    }
  }
})
View Code

wx.json

{
  "component": true
}
View Code

 

其他开始跳转的首页tabBar wx.js  中的onShow函数中加入  把选择框修改值即可

  if (typeof this.getTabBar === 'function' &&
      this.getTabBar()) {
      this.getTabBar().setData({
        selected:30
      })
    }
View Code

 

底部导航栏内 登录 与不登录 后样式修改变化

 

 

登录后

 

 

 在根目录 和pages 同级别的目录创建custom-tab-bar组件

index.js

const app = getApp();
Component({
  data: {
    selected: 0,
    login: app.globalData.userInfo ? 1 : 0,
    "color": "#999999",
    "selectedColor": "#1B88EE",
    "list": [{
        "pagePath": "/pages/tabar/frontpage/index",
        "text": `${app.globalData.userInfo?'工作台':'首页'}`,
        "iconPath": "/images/tab_icon_grzx_normal.png",
        "selectedIconPath": "/images/tab_icon_grzx_pressed.png"
      },
      {
        "pagePath": "/pages/tabar/person/index",
        "text": "个人中心",
        "iconPath": "/images/tab_icon_sy_normal.png",
        "selectedIconPath": "/images/tab_icon_sy_pressed.png"
      }
    ]
  },
  attached() {
    this.checkLogin();
  },

  methods: {
    switchTab(e) {
      const data = e.currentTarget.dataset;
      const url = data.path

      wx.switchTab({
        url
      })
      this.setData({
        selected: data.index
      })
    },
    checkLogin() {
      const that = this;
      if (app.globalData.userInfo) {
        let obj = {
          "pagePath": "/pages/tabar/frontpage/index",
          "text": `${ app.globalData.userInfo ? '工作台':'首页'}`,
          "iconPath": "/images/tab_icon_grzx_normal.png",
          "selectedIconPath": "/images/tab_icon_grzx_pressed.png"
        }
        let list = that.data.list;
        list.splice(0, 1, obj);
        that.setData({
          list,
          userInfo: app.globalData.userInfo
        })
      }else{
        //未登录 循环调用
        setTimeout(()=>{
          that.checkLogin()
        },2000)
      }
    }
  },
})
View Code

index.jaon

{
  "usingComponents": {},
  "component": true
}
View Code

index.wxml

<!--custom-tab-bar/index.wxml-->
<view class="tab-bar">
  <view wx:for="{{list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}" data-index="{{index}}" bindtap="switchTab">
    <image src="{{selected === index ? item.selectedIconPath : item.iconPath}}"></image>
    <view style="color: {{selected === index ? selectedColor : color}}">{{item.text}}</view>
  </view>
</view>
View Code

index.wxss

/* custom-tab-bar/index.wxss */


.tab-bar {
    position: fixed;
    z-index: 10;
    bottom: 0;
    left: 0;
    right: 0;
    box-sizing: border-box;
    padding: 20rpx 0 0;
    height: 120rpx;
    box-sizing: border-box;
    background: white;
    display: flex;
    box-shadow: 0px -6rpx 30rpx 0px rgba(0, 0, 0, 0.05);
  }
  
  
  
  .tab-bar-item {
    flex: 1;
    text-align: center;
    display: flex;
    align-items: center;
    flex-direction: column;
  }
  
  .tab-bar-item image {
    width: 48rpx;
    height: 48rpx;
    margin-bottom: 7rpx;
  }
  
  .tab-bar-item view {
    height: 20rpx;
    font-size: 20rpx;
    font-family: PingFangSC-Regular, PingFang SC;
    font-weight: 400;
    color: #A5AAAE;
    line-height: 20px;
  }
View Code

 

app.js

// app.js
App({
  onLaunch() {
    // 展示本地存储能力
    const logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs),


      // 登录
      wx.login({
        success: res => {
          // 发送 res.code 到后台换取 openId, sessionKey, unionId
        }
      })
  },
  onShow() {
    const self=this;
    wx.getStorage({
      key: 'userInfo',
      success (res) {
        if(res.data){
          self.globalData.userInfo=res.data;
        }
      }
    })
  },
  globalData: {
    userInfo: null
  },
})
View Code

app.json

{
  "pages": [
    "pages/index/index",
    "pages/logs/logs",
    "pages/tabar/frontpage/index",
    "pages/tabar/person/index",
    "custom-tab-bar/index"
  ],
  "window": {
    "backgroundTextStyle": "light",
    "navigationBarBackgroundColor": "#fff",
    "navigationBarTitleText": "Weixin",
    "navigationBarTextStyle": "black"
  },
  "tabBar": {
    "custom": true,
    "color": "#999999",
    "selectedColor": "#1B88EE",
    "borderStyle": "white",
    "backgroundColor": "#FAF9F9",
    "list": [
      {
        "pagePath": "pages/tabar/frontpage/index",
        "text": "首页",
        "iconPath": "images/tab_icon_grzx_normal.png",
        "selectedIconPath": "images/tab_icon_grzx_pressed.png"
      },
      {
        "pagePath": "pages/tabar/person/index",
        "text": "个人中心",
        "iconPath": "images/tab_icon_sy_normal.png",
        "selectedIconPath": "images/tab_icon_sy_pressed.png"
      }
    ]
  },
  "style": "v2",
  "sitemapLocation": "sitemap.json"
}
View Code

 

首页tabar页面 点击登录 及tabar跳转需要添加的方法

index.js

// pages/tabar/frontpage/index.js
const app = getApp();
Page({

  /**
   * 页面的初始数据
   */
  data: {
    items: [{
        id: 'id_one',
        text: '上课报名'
      },
      {
        id: 'id_two',
        text: '我的课表'
      },
      {
        id: 'id_three',
        text: '考勤请假'
      },
      {
        id: 'id_four',
        text: '我的订单'
      }
    ],
    userInfo: ''
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },

  onShow: function () {
    app.onShow();
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {
    this.setData({
      userInfo: app.globalData.userInfo ? app.globalData.userInfo : ''
    })
  },
  login() {
    const that = this;
    wx.getUserProfile({
      desc: '用于完善会员资料', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
      success: (res) => {
        wx.setStorage({
          key: 'userInfo',
          data: res.userInfo,
        });
        wx.getStorage({
          key: 'userInfo',
          success(res) {
            app.globalData.userInfo = res.data;
            that.setData({
              userInfo: res.data
            },()=>{
              console.log(app.globalData,'---');
            })
          }
        })
      }
    })
  },
  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {
    if (typeof this.getTabBar === 'function' &&
      this.getTabBar()) {
      this.getTabBar().setData({
        selected: 0
      })
    }
  },
  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})
View Code

index.xml

<!-- pages/tabar/frontpage/index.wxml -->
<view-scroll scroll-y="true" class="scroll_view">
    <view class="header">
        <view class="header_top">
            <image src="{{userInfo.avatarUrl}}" class="img_back img {{userInfo?'':'no_active'}}" />
            <button class="btn" open-type="getUserInfo" bindtap="login" wx:if="{{!userInfo}}">
                立即登录
            </button>
            <view class="login_name" wx:if="{{userInfo}}">{{userInfo.nickName}}</view>
        </view>
        <swiper class="special_swiper" indicator-dots="false" indicator-color="#B1AAA4" indicator-active-color="#FFFFFF" autoplay="false" current="0" current-item-id="" interval="5000" duration="1000" circular="false" vertical="{{false}}" previous-margin="false" next-margin="0px" display-multiple-items="1" skip-hidden-item-layout="false" bindchange="" bindanimationfinish="">
            <swiper-item>hello</swiper-item>
            <swiper-item>world</swiper-item>
        </swiper>
    </view>
    <view class="main">
        <view class="list">
            <block wx:for="{{items}}">
                <view class="item">
                    <view class="i_img img_back {{item.id}}"></view>
                    <view class="i_title">{{item.text}}</view>
                </view>
            </block>
        </view>
        <view class="evaluation">
            <view class="e_title">课堂评价</view>
            <view class="e_no_con">暂无课堂评价</view>
        </view>
    </view>
</view-scroll>
View Code

index.wxss

.img_back {
    background-repeat: no-repeat;
    background-size: 100% 100%;
}

.scroll_view {
    width: 750rpx;
    height: 100vh;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
}

.header {
    width: 750rpx;
    height: 512rpx;
    box-sizing: border-box;
}

.header_top {
    width: 750rpx;
    height: 104rpx;
    box-sizing: border-box;
    padding: 0 40rpx;
    display: flex;
    margin: 30rpx 0;
    background: #FFFFFF;
}

.header_top .img {
    width: 104rpx;
    height: 104rpx;
    border-radius: 50%;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    -o-border-radius: 50%;
    margin-right: 30rpx;
    display: block;
}

.header_top .img.no_active {
    background-image: url("");
}

.header_top .btn {
    box-sizing: border-box;
    padding: 0;
    margin: 20rpx 0;
    width: 146rpx;
    height: 64rpx;
    background: linear-gradient(90deg, #1B88EE 0%, #4CA8FF 100%);
    border-radius: 34rpx;
    -webkit-border-radius: 34rpx;
    -moz-border-radius: 34rpx;
    -ms-border-radius: 34rpx;
    -o-border-radius: 34rpx;
    font-size: 24rpx;
    font-family: PingFangSC-Medium, PingFang SC;
    font-weight: 500;
    color: #FFFFFF;
    line-height: 64rpx;
}

.header_top .login_name {
    margin-top: 34rpx;
    width: 108rpx;
    height: 36rpx;
    font-size: 36rpx;
    font-family: PingFangSC-Medium, PingFang SC;
    font-weight: 500;
    color: #222222;
    line-height: 36rpx;
}

.header .special_swiper {
    width: 678rpx;
    height: 308rpx;
    background: #D8D8D8;
    border-radius: 20rpx;
    -webkit-border-radius: 20rpx;
    -moz-border-radius: 20rpx;
    -ms-border-radius: 20rpx;
    -o-border-radius: 20rpx;
    margin: 0 36rpx 40rpx;
}


.scroll_view .main {
    flex: 1;
    width: 750rpx;
    box-sizing: border-box;
    background: #F7F7F7;
}

.scroll_view .main .list {
    width: 750rpx;
    box-sizing: border-box;
    padding: 4rpx 36rpx 60rpx;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.scroll_view .main .list .item {
    display: flex;
    flex-direction: column;
    width: 202rpx;
    height: 206rpx;
    background: #FFFFFF;
    border-radius: 20rpx;
    align-items: center;
    justify-content: center;
    margin-top: 36rpx;
    -webkit-border-radius: 20rpx;
    -moz-border-radius: 20rpx;
    -ms-border-radius: 20rpx;
    -o-border-radius: 20rpx;
}


.scroll_view .main .list .item .i_img {
    width: 72rpx;
    height: 72rpx;
    margin: 40rpx auto 20rpx;
}

.scroll_view .main .list .item .i_title {
    width: 104rpx;
    height: 34rpx;
    font-size: 26rpx;
    font-family: PingFangSC-Regular, PingFang SC;
    font-weight: 400;
    color: #222222;
    line-height: 34rpx;
    display: block;
    margin: 0 auto;
}

.id_one {
    background-image: url("");
}

.id_two {
    background-image: url("");
}

.id_three {
    background-image: url("");
}

.id_four {
    background-image: url("");
}


.scroll_view .main .evaluation {
    display: flex;
    flex-direction: column;
}

.scroll_view .main .evaluation .e_title {
    width: 750rpx;
    padding-left: 36rpx;
    height: 40rpx;
    font-size: 32rpx;
    font-family: PingFangSC-Medium, PingFang SC;
    font-weight: 500;
    color: #222222;
    line-height: 40rpx;
    box-sizing: border-box;
}

.scroll_view .main .evaluation .e_no_con {
    width: 750rpx;
    height: 152rpx;
    text-align: center;
    font-size: 28rpx;
    font-family: PingFangSC-Regular, PingFang SC;
    font-weight: 400;
    color: #999999;
    line-height: 152rpx;
}
View Code

 

posted @ 2021-08-18 09:46  还有什么值得拥有  阅读(976)  评论(0编辑  收藏  举报