zoukankan      html  css  js  c++  java
  • 小程序封装API

    一般我们https请求都是通过wx.request来请求,但是这种请求如果多了,页面会混乱不说,还不好管理,因此我将请求单独拎出去,方便管理,也方便后期维护。
    // api.js
    const API_BASE_URL = 'http://xxx';
    const request = (url, data) => { 
      let _url = API_BASE_URL  + url;
      return new Promise((resolve, reject) => {
        wx.request({
          url: _url,
          method: "get",
          data: data,
          header: {
            'Content-Type': 'application/x-www-form-urlencoded'
          },
          success(request) {
            resolve(request.data)
            
          },
          fail(error) {
            reject(error)
          }
        })
      });
    }
    
    
    module.exports ={
      gethotsongs:(data) =>{
        return request('/search/hot',data)//热搜接口
      },
      searchSuggest:(data)=>{
        return request('/search/suggest',data)//搜索建议接口
      },
      searchResult:(data)=>{
        return request('/search',data)//搜索结果接口
      },
      getBanner:(data)=>{
        return request('/banner',data)//个性推荐轮播
      },
      getsongsheet:(data)=>{
        return request('/top/playlist',data)//热门歌单接口
      },
      getNewSong:(data)=>{
        return request('/personalized/newsong',data)//最新音乐接口
      },
      getDjRadios:(data)=>{
        return request('/dj/recommend',data)//电台推荐接口
      },
      getProgramRecommend:(data)=>{
        return request('/program/recommend',data)//推荐节目接口
      },
      getRecommendType:(data)=>{
        return request('/dj/recommend/type',data)//所有电台分类推荐
      },
      getRecommendMV:(data)=>{
        return request('/personalized/mv',data)//推荐MV
      },
      getNewMv:(data)=>{
        return request('/mv/first',data)//最新MV
      },
      getNewEst:(data)=>{
        return request('/album/newest',data)//最新专辑
      },
      getTopList:(data)=>{
        return request('/top/list',data)//排行榜
      },
      getDjList:(data)=>{
        return request('/dj/catelist',data) //电台分类
      },
      getPay:(data)=>{
        return request('/dj/paygift',data)//付费精品
      },
      getSonger:(data)=>{
        return request('/toplist/artist',data)//歌手排行
      }
    }

    只需要在使用的页面引入就好

    const API = require('/config/api')

    下面以个性推荐轮播图为例

      getBanner: function() {
        API.getBanner({
          type: 2
        }).then(res => {
          if (res.code === 200) { //更加严谨
            this.setData({
              banner: res.banners
            })
          }
        })
      }

    参考链接:https://juejin.im/post/5d10c899f265da1bae390749

  • 相关阅读:
    snaker数据库表说明
    Oracle 导入、导出DMP(备份)文件
    eclipse debug无法启动
    java----事务
    java----单例模式
    java----spring框架
    mybatis----批量增加与批量删除
    web应用程序状态管理
    JavaWeb----servlet
    HTML / CSS----元素分类
  • 原文地址:https://www.cnblogs.com/cap-rq/p/11410950.html
Copyright © 2011-2022 走看看