摘要:實現方案首先小程序目前還是不支持的和的,那么如何讓它支持呢點擊下載,并把下載好的文件夾放到自己小程序的目錄下,包總共才多,體積很小的。如果想使用這些新的對象和方法,必須使用,為當前環境提供一個墊片。用于實現瀏覽器并不支持的原生的代碼。
前言
在平常的項目開發中肯定會遇到同步異步執行的問題,還有的就是當執行某一個操作依賴上一個執行所返回的結果,那么這個時候你會如何解決這個問題呢;
1.是用settimeout讓它異步執行,顯然這只是讓它加入異步任務隊列中去執行,但并不能保證等待其返回結果再去執行另一個操作。 2.還是自己封裝callback函數?那樣就會陷入所謂的回調地獄,代碼層層嵌套,環環相扣,邏輯稍微復雜就會很難去維護。 3.當然es6中的promise倒是很好的解決了這樣的問題,再配合es7的async和await就更完美了,await返回的也是一個promise對象,這個關于promise和async,await的使用方法就不說了。實現方案
首先小程序目前還是不支持es7的async和await的,那么如何讓它支持呢 1、點擊下載
regenerator,并把下載好的runtime.js文件夾放到自己小程序的utils目錄下,包總共才20kb多,體積很小的。
2、在需要調的地方引入 import regeneratorRuntime from "../../utils/runtime.js" 3、如何封裝并使用
封裝:
const postData = async function(url, data) { wx.showLoading({ title: "加載中", }) let promiseP = await new Promise(function(resolve, reject) { wx.request({ url: baseUrl + url, data: data, method: "POST", header: { "content-type": "application/json", "access-token": wx.getStorageSync("token") }, success: function(res) { wx.hideLoading(); if (res.statusCode === 200) { resolve(res) } else { reject(res.data) } }, fail: function(err) { wx.hideLoading(); reject(err) if (err.code === 401) {} } }) }) return promiseP } module.exports = { postData }
使用:
import regeneratorRuntime from "../../utils/runtime.js"; const app = getApp(), postData = require("../../service/koalaApi.js"); async demo() { await postData(app.globalData.baseUrl + "/test",{ data: {} }).then((res) => { console.log(res) }) }
下面進行了更完善的一個封裝,包括各種錯誤判斷的處理和簡化,通過傳參的方式,來靈活調用
// 當前host const url_host = require("API.js").host // 當前版本 const currentVersion = require("util.js").currentVersion // 當前路徑 import { currentPagePath } from "util.js" // 調用fetch方法,然后依次鏈式傳入 // url, method, header, data, loading(是否顯示loading) function fetch(url, method, header, data, loading) { // 判斷給服務端傳遞undefined的問題 let fetchP = new Promise(function (resolve, reject) { if (loading) { wx.showLoading({ icon: "loading" }) } if(data && data.unionId && typeof data.unionId === "undefined"){ wx.hideLoading() return reject({ ok:false, error: "unionId -> " + typeof data.unionId }); } wx.request({ url: url_host + url, method: method ? method : "GET", header: { "content-type": "application/json", // 默認值 "version": currentVersion, "pagePath": currentPagePath() }, data: data, success: function (res) { if (res.statusCode < 500) { resolve(res.data) } else { showError() reject(res.data) } }, fail: function (err) { showError() reject(err) }, complete: function (comp) { if (loading) { wx.hideLoading() } } }) }) return fetchP } // 服務器開小差了 function showError () { wx.hideLoading() // 獲取頭文件路徑 wx.navigateTo({ url: "/pages/serverError/serverError", }) } module.exports = { fetch }思考
1、為什么引入regeneratorRuntime,就能夠使用async/await?不需要配合babel嗎?
2、regeneratorRuntime都做了什么?
總結1、首先先明白babel和polyfill分別干啥的;
Babel 是一個廣泛使用的轉碼器,Babel 默認只轉換新的 JavaScript 句法,而不轉換新的 API。 例如,Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise 等全局對象,以及一些定義在全局對象上的方法(比如 Object.assign)都不會轉譯。 如果想使用這些新的對象和方法,必須使用 babel-polyfill,為當前環境提供一個墊片。
2、Polyfill用于實現瀏覽器并不支持的原生API的代碼。
3、在明白上面的意思之后,還需要明白的是,babel-polyfill是一股腦把全部都給你添加到js文件中,而現在的runtime將會判斷你哪些需要加載的,有選擇性的進行加載,并且后者也不會污染全局變量。在這里regeneratorRuntime最終轉化成es6的generator來用的。具體的可以自己去下babel官網,輸入相關代碼可以看下最終轉換后的代碼。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/101206.html
摘要:美團小程序框架入門教程自打寫了美團小程序框架蹲坑指南一發不可收拾,今天趁周末空閑,來寫個沒朋友的簡單入門教程,本教程只針對新手,老鳥勿噴。 美團小程序框架mpvue入門教程 自打寫了 美團小程序框架mpvue蹲坑指南,一發不可收拾,今天趁周末空閑,來寫個mpvue(沒朋友)的簡單入門教程,本教程只針對新手,老鳥勿噴。 另外,我還專門為本文做了一個簡單的項目,如果懶得從頭開始搭項目的童鞋...
摘要:一起打車吧微信小程序依然是一個玩具般的存在,僅供自己學習和探索,當然也歡迎各位讀者能夠貢獻代碼,參與開發 小程序名稱:一起打車吧 項目地址:客戶端:https://github.com/jrainlau/t... 服務端:https://github.com/jrainlau/t... 小程序二維碼:showImg(https://segmentfault.com/img/bV80...
摘要:一起打車吧微信小程序依然是一個玩具般的存在,僅供自己學習和探索,當然也歡迎各位讀者能夠貢獻代碼,參與開發 小程序名稱:一起打車吧 項目地址:客戶端:https://github.com/jrainlau/t... 服務端:https://github.com/jrainlau/t... 小程序二維碼:showImg(https://segmentfault.com/img/bV80...
閱讀 2772·2021-11-19 11:30
閱讀 3058·2021-11-15 11:39
閱讀 1782·2021-08-03 14:03
閱讀 1985·2019-08-30 14:18
閱讀 2043·2019-08-30 11:16
閱讀 2149·2019-08-29 17:23
閱讀 2597·2019-08-28 18:06
閱讀 2533·2019-08-26 12:22