99偷拍视频精品区一区二,口述久久久久久久久久久久,国产精品夫妇激情啪发布,成人永久免费网站在线观看,国产精品高清免费在线,青青草在线观看视频观看,久久久久久国产一区,天天婷婷久久18禁,日韩动漫av在线播放直播

微信小程序HTTP請求從0到1封裝的方法-創新互聯

這篇文章主要講解了“微信小程序HTTP請求從0到1封裝的方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“微信小程序HTTP請求從0到1封裝的方法”吧!

創新互聯建站服務項目包括南靖網站建設、南靖網站制作、南靖網頁制作以及南靖網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,南靖網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到南靖省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!

HTTP庫


1、jQuery的$.ajax


調用了XMLHttpRequest對象,封裝在相關函數在配置項中,一旦傳入了必需選項,則直接調用相應的send()方法進行數據的請求


2、Axios


基于Promise的請求庫,通過判斷XMLHTTPRequest對象存在與否,來支持客戶端和node服務端發送請求,封裝的很不錯的HTTP庫,支持promise、攔截請求和響應等


小程序網絡請求


wx.request({
 url: 'test.php', //僅為示例,并非真實的接口地址
 data: {
 x: '',
 y: ''
 },
 header: {
 'content-type': 'application/json' // 默認值
 },
 success (res) {
 console.log(res.data)
 }
})

小程序本身的請求已經封裝的很不錯了,使用起來和$.ajax相似,支持許多配置項的設置,但是缺少公共配置、響應和請求攔截等實用功能


第一步--創建請求實例


class Axios {
 constructor() {
  this.instance = null // 類的實例
  this.config = defaultConfig
 }

 create(instanceConfig) {
  const { config } = this
  // 創建實例的時候添加基本配置
  this.config = {
   ...config,
   ...instanceConfig
  }
  return this
 }

 // 單例
 static getInstance() {
  if (!this.instance) {
    this.instance = new Axios()
  }
  return this.instance
 }
}

創建實例


const axios = Axios.getInstance()

promise包裝小程序請求


const dispatchRequest = function(config) {
 return new Promise((resolve, reject) => {
  wx.request({
   ...config,
   url: config.base + config.url,
   success: res => {
    resolve(res)
   },
   fail: res => {
    reject(res)
   }
  })
 })
}

給請求實例添加request方法


request(options) {
 const { config } = this
 // 實例請求的時候添加基本配置
 const requsetOptions = {
  ...config,
  ...options
 }
 return dispatchRequest(requsetOptions)
}

第二步--創建請求工具方法


創建實例,通過create設置基本配置項


const instance = (config = {}) => {
 return axios.create({
  base: globalApi,
  ...config
 })
}

創建請求工具方法,執行實例request


export function request(options) {
 const { baseConfig, url, method, data, isLogin } = options
 instance(baseConfig)
  .request({
   url,
   method: method || 'GET',
   data
  })
  .then(res => {
   options.success && options.success(res)
  })
  .catch(err => {
   if (options.error) {
    options.error(err)
   } else {
    errAlert()
   }
  })
 }
}

這樣,一個請求的工具方法就完成了,但是這個方法現在只支持基本的請求和基本配置項的配置,還是缺少我們很常用的公共請求和響應的攔截。


第三部--添加請求和響應的攔截器


創建攔截器實例


class InterceptorManager {
 constructor() {
  this.fulfilled = null
  this.rejected = null
 }

 use(fulfilled, rejected) {
  this.fulfilled = fulfilled
  this.rejected = rejected
 }
}

在請求實例的構造方法中添加請求和響應攔截實例


constructor() {
 this.instance = null // 類的實例
 this.config = defaultConfig
 this.interceptors = {
  request: new InterceptorManager(),
  response: new InterceptorManager()
 }
}

在實例的request添加promise執行隊列


request(options) {
  const { config, interceptors } = this
  // 實例請求的時候添加基本配置
  const requsetOptions = {
   ...config,
   ...options
  }

  const promiseArr = [] // promise存儲隊列

  // 請求攔截器
  promiseArr.push({
   fulfilled: interceptors.request.fulfilled,
   rejected: interceptors.request.rejected
  })

  // 請求
  promiseArr.push({
   fulfilled: dispatchRequest,
   rejected: null
  })

  // 回調攔截器
  promiseArr.push({
   fulfilled: interceptors.response.fulfilled,
   rejected: interceptors.response.rejected
  })

  let p = Promise.resolve(requsetOptions)
  promiseArr.forEach(ele => {
   p = p.then(ele['fulfilled'], ele['rejected'])
  })

  return p
 }

在請求工具方法中通過設置請求和響應的攔截方法


axios.interceptors.request.use(
 request => {
  return request
 },
 err => {
  console.error(err)
 }
)
axios.interceptors.response.use(
 response => {
  return response
 },
 err => {
  console.error(err)
 }
)

在請求攔截方法里面可以添加數據轉換,在請求頭部添加sign、token等,在響應攔截方法里面去做公共的數據處理等


感謝各位的閱讀,以上就是“微信小程序HTTP請求從0到1封裝的方法”的內容了,經過本文的學習后,相信大家對微信小程序HTTP請求從0到1封裝的方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創新互聯網站建設公司,,小編將為大家推送更多相關知識點的文章,歡迎關注!

本文標題:微信小程序HTTP請求從0到1封裝的方法-創新互聯
地址分享:http://www.yijiale78.com/article11/ceeegd.html

成都網站建設公司_創新互聯,為您提供手機網站建設云服務器網站設計公司外貿建站網站制作網站導航

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

商城網站建設