最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 微信小程序开发(一)

    正文概述 掘金(Jimmy)   2021-03-29   445

    本文约一千字,约耗费您4分钟

    上次写的小程序-从零开发简易微信小程序只有单个页面,比较简单明了。

    周日聊天,吐槽着今天无聊,天气太热,得找点事情来做下,于是想起了小程序这块。

    嗯~可以把这个小程序当成一个产品来慢慢开发,不错的主意!

    今天将在小程序中添加底部tab功能切换,并新增关于我的功能:

    微信小程序开发(一)

    1.新增tabs

    其实微信开发开发文档中已经有配置说明自定义tabBar。直接在app.json中的tabBar项中指定即可:

    "list": [
      {
        "pagePath": "pages/index/index",
        "text": "京东商品"
      }, 
      {
        "pagePath": "pages/about/about",
        "text": "关于我"
      }
    ]
    

    然而,效果令人很是不满意:

    微信小程序开发(一)

    所以,算了,我们不使用官方的tabbar组件,我们使用vant来封装一个~

    <!--tabBar.wxml-->
    <view class="tabBar">
      <van-tabbar 
        active="{{ active }}" 
        active-color="#EC644E"
        inactive-color="#000">
        <van-tabbar-item 
          wx:for="{{tabs}}" 
          wx:key="index" 
          icon="{{item.icon}}"
          data-item="{{item}}"
          data-index="{{index}}"
          bindtap="changeTab">
          {{item.name}}
        </van-tabbar-item>
      </van-tabbar>
    </view>
    
    // tabBar.js
    Component({
      data: {
        active: 0,
        tabs: [{
          icon: 'home-o',
          name: '京东商城',
          path: '/pages/index/index' 
        }, {
          icon: 'user-o',
          name: '关于我',
          path: '/pages/about/about'
        }]
      },
      methods: {
        changeTab(e) {
          let dataset = e.currentTarget.dataset,
            activeTab = dataset.index,
            item = dataset.item; 
          this.setData({ 
            active: activeTab
          });
          wx.navigateTo({
            url: item.path
          });
        },
      }
    })
    

    当然,我们还得引入vant的组件:

    # tabBar.json
    {
      "component": true,
      "usingComponents": {
        "van-icon": "/miniprogram_npm/vant-weapp/icon/index",
        "van-tabbar": "/miniprogram_npm/vant-weapp/tabbar/index",
        "van-tabbar-item": "/miniprogram_npm/vant-weapp/tabbar-item/index"
      }
    }
    

    效果如下:

    微信小程序开发(一)

    嗯~不赖

    2.关于我

    关于我的模块,因为此小程序目前没什么板块内容,这里只是添加了用户基本信息的展示和此微信小程序的说明。

    2.1获取用户基本信息

    这里的用户基本信息包括用户的头像,昵称,所在的区域。

    在未登陆的情况下,我们可以通过open-data直接获取到用户的头像。

    <open-data class="avatar" type="userAvatarUrl"></open-data>
    

    在用户对我们的产品进一步需要的场景下-比如下单购买商品需要用户去登陆,那么这个时候,我们必须得拿到用户的相关的信息,这里我获取到的信息比较简单,通过openType="getUserInfo"的授权就可以了。真实场景下,需要我们有接口去存放用户的信息,我这里直接用缓存去存放~

    wx.setStorageSync("user_info", userInfo);
    

    相关wxml的代码如下:

    <!--me.wxml-->
    <view class="main-container">
    <van-cell>
      <button slot="title" class="avatar-flex" openType="getUserInfo" bindgetuserinfo="handleUserInfo">
        <open-data class="avatar" type="userAvatarUrl"></open-data>
        <view class="avatar-hint" wx:if="{{userInfo.nickName}}">{{userInfo.nickName}}</view>
        <view class="avatar-hint" wx:else>请授权</view>
      </button>
      <view class="avatar-extra" wx:if="{{userInfo.nickName}}">{{userInfo.province}} {{userInfo.country}}</view>
    </van-cell>
    </view>
    

    效果如图:

    微信小程序开发(一)

    目前关于的内容比较少,我们做手风琴效果处理,而不是新开一个页面,不然页面内容更加空洞改了:

    <van-collapse accordion value="{{ activeCollapse }}" bind:change="onChange">
      <van-collapse-item  icon="shop-o" name="1">
        {{aboutTxt}}
      </van-collapse-item>
    </van-collapse>
    

    效果如下:

    微信小程序开发(一)

    整体关于我板块效果如下图:

    微信小程序开发(一)

    后话

    至此,已经完成✅ tabbar关于我的板块。至于下一个小迭代做啥,我也不知道~嗯,有苗头再改动。微信小程序开发(二) 文章也许会迟到,但是不会缺席。

    • 更多内容,请移步github.com/reng99

    码字不易,走过路过来个赞可否?!

    ε=ε=ε=┏(゜ロ゜;)┛


    起源地下载网 » 微信小程序开发(一)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元