weex stream 方法封装

Posted 每天都要进步一点点

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了weex stream 方法封装相关的知识,希望对你有一定的参考价值。

1.封装

api.js

// 配置API接口地址
const baseUrl = ‘http://www.kuitao8.com/‘;

// 引入 弹窗组件
var modal = weex.requireModule(‘modal‘);
// 引入 请求数据组件
var stream = weex.requireModule(‘stream‘);
// 身份验证
import jwtdecode from ‘jwt-simple‘;

// 自定义判断元素类型JS
function toType (obj) {
  return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase()
}

// 参数过滤函数
function filterNull (o) {
  for (var key in o) {
    if (o[key] === null) {
      delete o[key]
    }
    if (toType(o[key]) === ‘string‘) {
      o[key] = o[key].trim()
    } else if (toType(o[key]) === ‘object‘) {
      o[key] = filterNull(o[key])
    } else if (toType(o[key]) === ‘array‘) {
      o[key] = filterNull(o[key])
    }
  }
  return o
}

// 工具方法
function toParams(obj) {
  var param = ""
  for(const name in obj) {
    if(typeof obj[name] != ‘function‘) {
      param += "&" + name + "=" + encodeURI(obj[name])
    }
  }
  return param.substring(1)
};

/**
 * 接口处理函数
 */
function apiStream (method, url, params, success, failure) {
  // 过滤参数
  if (params) {
    params = filterNull(params)
  }

  /*** stream ***/
  if(method === ‘GET‘){
    // GET 方法
    stream.fetch({
      method: ‘GET‘,
      type: ‘text‘,
      url: baseUrl + url + toParams(params)
    }, function(res) {
      if (res.ok) {
        // 解密
        let currentData = jwtdecode.decode(res.data, ‘michahzdee2016‘, ‘HS256‘);
        success(currentData);
      }else {
        modal.toast({
          message: ‘请求失败,请检查网络!‘,
          duration: 2
        })
      }
    })
  }else if(method === ‘POST‘){
    // POST 方法
    stream.fetch({
      method: ‘POST‘,
      type: ‘text‘,
      url: baseUrl + url,
      headers: {‘Content-Type‘:‘application/x-www-form-urlencoded‘},
      body: toParams(params)
    }, function(res) {
      if (res.ok) {
        // 解密
        let currentData = jwtdecode.decode(res.data, ‘michahzdee2016‘, ‘HS256‘);
        success(currentData);
      }else {
        modal.toast({
          message: ‘请求失败,请检查网络!‘,
          duration: 2
        })
      }
    },function(progress) {
      //
    })
  }
};

// 返回在vue模板中的调用接口
export default {
  get: function (url, params, success, failure) {
    return apiStream(‘GET‘, url, params, success, failure)
  },
  post: function (url, params, success, failure) {
    return apiStream(‘POST‘, url, params, success, failure)
  },
  put: function (url, params, success, failure) {
    return apiStream(‘PUT‘, url, params, success, failure)
  },
  delete: function (url, params, success, failure) {
    return apiStream(‘DELETE‘, url, params, success, failure)
  }
}

 

2.entry.js  全局注册

import api from ‘./api‘
// 将API方法绑定到全局
Vue.prototype.$api = api

 

3.页面调用

let params = {
  catid:10,
  pagesize:20
}
/*请求数据*/
this.$api.get(‘webservice/Api/List?‘,params,function(data) {
  console.log(JSON.stringify(data));
})

.

以上是关于weex stream 方法封装的主要内容,如果未能解决你的问题,请参考以下文章

eeui的postget请求封装

weex用阿里矢量图

Weex内置模块——storage模块

VsCode 代码片段-提升研发效率

VSCode自定义代码片段14——Vue的axios网络请求封装

VSCode自定义代码片段14——Vue的axios网络请求封装