微信小程序初步的全局文件的创建(1)

微信小程序(配置):
config.js
在这里插入图片描述
token.js:

// 引用使用es6的module引入和定义
// 全局变量以g_开头
// 私有函数以_开头

import { Config } from 'config.js';
class Token {
    constructor() {
        this.tokenUrl = Config.restUrl + 'token/user';
        this.verifyUrl = Config.restUrl + 'token/verify';
    }
    verify() {
        var token = wx.getStorageSync('token');
        if (!token) {
            this.getTokenFromServer();
        }
        else {
            this._veirfyFromServer(token);
        } 
    }
    _veirfyFromServer(token) {
        var that = this;
        wx.request({
            url: that.verifyUrl,
            method: 'POST',
            data: {
                token: token
            },
            success: function (res) {
                var valid = res.data.isValid;
                if(!valid){
                    that.getTokenFromServer();
                }
            }
        })
    }
    getTokenFromServer(callBack) {
        var that  = this;
        wx.login({
            success: function (res) {
                wx.request({
                    url: that.tokenUrl,
                    method:'POST',
                    data:{
                        code:res.code
                    },
                    success:function(res){
                        wx.setStorageSync('token', res.data.token);
                        callBack&&callBack(res.data.token);
                    }
                })
            }
        })
    }
}
export {Token};

Base:

import { Token } from 'token.js';
import { Config } from 'config.js';

class Base {
    constructor() {
        "use strict";
        this.baseRestUrl = Config.restUrl;
        this.onPay=Config.onPay;
    }
    //http 请求类, 当noRefech为true时,不做未授权重试机制
    request(params, noRefetch) {
        var that = this,
            url=this.baseRestUrl + params.url;
        if(!params.type){
            params.type='get';
        }
        /*不需要再次组装地址*/
        if(params.setUpUrl==false){
            url = params.url;
        }
        wx.request({
            url: url,
            data: params.data,
            method:params.type,
            header: {
                'content-type': 'application/json',
                'token': wx.getStorageSync('token')
            },
            success: function (res) {

                // 判断以2(2xx)开头的状态码为正确
                // 异常不要返回到回调中,就在request中处理,记录日志并showToast一个统一的错误即可
                var code = res.statusCode.toString();
                var startChar = code.charAt(0);
                if (startChar == '2') {
                    params.sCallBack && params.sCallBack(res.data);
                } else {
                    if (code == '401') {
                        if (!noRefetch) {
                            that._refetch(params);
                        }
                    }
                    that._processError(res);
                    params.eCallBack && params.eCallBack(res.data);
                }
            },
            fail: function (err) {
                //wx.hideNavigationBarLoading();
                that._processError(err);
                // params.eCallback && params.eCallback(err);
            }
        });
    }

    _processError(err){
        console.log(err);
    }

    _refetch(param) {
        var token = new Token();
        token.getTokenFromServer((token) => {
            this.request(param, true);
        });
    }

    /*获得元素上的绑定的值*/
    getDataSet(event, key) {
        return event.currentTarget.dataset[key];
    };

};

export {Base};

home_model.js:

import { Base } from '../../utils/base.js';
class Home extends Base{
 
  //定义构造函数
  constructor(){
    super();
  }
  getBannerData(id, callBack){
    var params = {
      url:'banner/' +id,
      sCallBack:function(res){
        callBack && callBack(res.items);
      }
    }
    this.request(params);
  }
  //主题加载
  getThemeData(callBack){
    var param = {
      url:'theme?ids=1,2,3',
      sCallBack: function(data){
        callBack && callBack(data);
      }
    }
    this.request(param);
  }
  //三个样式加载
  getProductsData(callBack){
    var param = {
      url:'product/recent',
      sCallBack: function(data){
        callBack && callBack(data);
      }
    }
    this.request(param);
  }
}
//输出出去
export{Home};

home.js:

// pages/home/home.js
// 实例化变量
import {Home} from 'home-model.js';
var home = new Home();
Page({
  /**
   * 页面的初始数据
   */
  data: {

  },
  //主页显示时,生命周期
  onLoad:function(){
   this._loadData();
  },
  _loadData:function(){
     var id = 1;
      home.getBannerData(id,(res)=>{
      //数据绑定
      this.setData({
        'bannerArr':res
      });
    });
    //主题绑定
    home.getThemeData((res)=>{
      // console.log(res);
    this.setData({
      'themeArr':res
    })
    });
    //三个样式的显示
    home.getProductsData((data)=>{
      // console.log(data);
    this.setData({
      'productsArr':data
    })
    });
  },
  //轮播图显示的=获取id
  onProductsItemTap: function(event){
    // console.log(event);
    // var id = event.currentTarget.dataset.id;
    var id = home.getDataSet(event,'id');
    wx.navigateTo({
      url: '../product/product?id='+id,
    })
  },
  //跳转的主题的页面
  onThemesItemTap: function(event){
    var id = home.getDataSet(event,'id');
    var name = home.getDataSet(event,'name');
    wx.navigateTo({
      url: '../theme/theme?id='+ id + '&name=' + name,
    })

  }
})
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骨子里的偏爱

上传不易,还请多多支持。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值