日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

解决代码中重复的捕获 promise 错误的 try catch 语句

發布時間:2024/4/13 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 解决代码中重复的捕获 promise 错误的 try catch 语句 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

promise

promise 的出現,提供了優雅的異步解決方式,但是,多個連續繼發 promise 寫法依然繁瑣。

let promise = new Promise(function(resolve, reject){// ...if(/* 異步任務執行成功 */) {resolve(value)} else {reject(error)} })promise.then(v => {}).catch(e => {}) 復制代碼

async

es6 之后又新增了 async 函數來優化異步寫法,語義化更明確,寫法更優雅,但是錯誤捕獲比較麻煩,一般都得使用 try catch 來捕獲錯誤,具體優點參考阮老師博客 async 函數

function promiseFunc = function(){return new Promise(function(resolve, reject){// ...if(/* 異步任務執行成功 */) {resolve(value)} else {reject(error)}}) }async func(){let res = await promiseFunc() }// 錯誤捕獲 async func(){try{let res = await promiseFunc()}catch(err){alert(err)} }復制代碼

錯誤捕獲優化

如下是工作中 react + mobx 項目中 action 的代碼

class Actions {@actionasync deleteModel(params) {try {await this.post(apis.API_DEPLOY_DELETE, params)this.getDeployList(this.store.searchParams)} catch (e) {message.error(e.message || '出錯了!請稍后重試')}}@actionasync getDirChain(params) {try {let r = await this.post(apis.API_DEPLOY_DIR_CHAIN, params)runInAction(() => {this.store.dirChain = r})} catch (e) {message.error(e.message || '出錯了!請稍后重試')}}} 復制代碼

如上代碼,兩個 action 都是向后端異步請求數據, 每個 action 函數中都用了 try catch 函數,這樣重復寫了幾十個 action 函數

必須干掉 try catch

錯誤捕獲裝飾器嘗試

裝飾器簡潔方便,首先嘗試, class 方法裝飾器函數如下

const tryCatch = msg => (target, name, descriptor) => {const original = descriptor.valueif (typeof original === 'function') {descriptor.value = async function(...args) {try {const result = await original.apply(this, args)return result} catch (e) {message.error(e.message || msg || '出錯了!請稍后重試')}}}return descriptor } 復制代碼

如上代碼,封裝 tryCatch 裝飾器來對每個 action 函數添加 try catch 錯誤捕獲。

屬性方法裝飾器中

  • target 指向 class 實例
  • name 是被裝飾的方法名
  • descriptor 是方法的屬性修飾符

我們可以通過 descriptor.value 獲取到被裝飾的方法,在 try catch 中執行函數,捕獲錯誤或者返回結果

為了靈活提示錯誤信息,裝飾器參數 msg 用來傳入自定義提示文本

  • 用法(該用法是錯誤的)
@tryCatch // @tryCatch('運行出錯') @action async getDirChain(params) {let r = await this.post(apis.API_DEPLOY_DIR_CHAIN, params)runInAction(() => {this.store.dirChain = r}) } 復制代碼

以上對 async 函數進行錯誤捕獲的用法是錯誤的

如上的寫法是錯誤的,這種裝飾器只能對同步代碼產生作用,異步的是無效的,之前理解錯誤了

最后還是解決了 try catch 問題

直接 async await 函數封裝就行了,簡單的問題想復雜了。。。

定義請求執行公共函數

/*** @param {string} method request method; ('get', 'post')* @param {string} api request url* @param {object} params payload* @memberof BaseActions*/ request = async (method, api, params = {}) => {const requestFunc = async () => {let r = nulltry {r = await this[method](api, params)} catch (e) {message.error(e.message)}return r}return await requestFunc() } 復制代碼

原有包含 try catch 重復代碼函數修改

@action async getDirChain(params) {let r = await this.request('get', apis.API_DEPLOY_DIR_CHAIN, params)r && runInAction(() => this.store.dirChain = r) } 復制代碼

終于不用不停寫重復代碼了。。。

總結

以上是生活随笔為你收集整理的解决代码中重复的捕获 promise 错误的 try catch 语句的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品黄色在线观看 | 思思99热 | 日韩欧美小视频 | 国产精品99久久久精品无码 | 国产日本精品视频 | 无码人妻丰满熟妇区96 | 日韩性生活视频 | 久久爱一区二区 | 综合九九| 久草黄色 | 伊人久久大香线蕉综合75 | 四虎永久免费地址 | 欧美老肥妇做爰bbww | 色黄网站 | 岛国精品一区 | 色姐 | 亚洲天堂导航 | 成人精品亚洲 | 国产精品zjzjzj在线观看 | 九九视频免费看 | 三级av免费 | 高清av免费| 99性趣网 | 九九九九久久久久 | 色香蕉网 | 亚洲666| 日本a视频在线观看 | 欧美黄色短片 | 中文字幕日韩一区二区 | 一区二区三区精彩视频 | 国产在线观看不卡 | 老女人一毛片 | 日韩在线免费视频 | 亚洲伊人成人网 | 欧美视频你懂的 | 五月激情小说网 | 日韩国产成人 | 两性av | 亚洲精品一区二区18漫画 | 黄色a大片 | 日本3级网站 | 影音先锋国产精品 | 很黄很污的视频 | 性饥渴的农村熟妇 | 中出av在线 | 最新中文字幕2019 | 草av| 少妇又色又爽又高潮极品 | 青青草成人免费在线视频 | 成人一区二区三区 | 久久99热这里只有精品 | 久久精品无码人妻 | 亚洲国产高清国产精品 | 婷婷激情五月网 | 在线成人免费视频 | 国产小视频在线播放 | 欧美综合日韩 | 九九热这里有精品 | 日本久久一级片 | 日本一区二区三区免费观看 | 97超碰人人澡人人爱学生 | 日韩精选视频 | 亚洲AV蜜桃永久无码精品性色 | 久久精品aⅴ无码中文字字幕重口 | 91麻豆精品国产理伦片在线观看 | 成人免费毛片aaaaaa片 | 懂色一区二区 | 女生扒开尿口让男生桶 | 88av网| 熟妇毛片 | 亚洲特黄 | 91激情在线观看 | 亚洲啊v在线 | 久久叉| 欧美午夜精品理论片a级按摩 | aaa天堂| 麻豆影视国产在线观看 | 久久亚洲激情 | 伊是香蕉大人久久 | 99国产精品久久久久久久成人 | 久久精品视频中文字幕 | 床戏高潮做进去大尺度视频网站 | 精品久久久久久久久久久久久久久久久久 | 久久国产一区二区 | 美女扒逼| 国产精品激情 | eeuss国产一区二区三区 | 重口味av | xxx黄色片| 成人免费观看网站 | 黄视频在线免费 | 一区二区三区人妻 | 欧美手机在线观看 | 日本黄色三级 | 久久人人爽人人爽人人 | 成年人黄色一级片 | 欧美日本中文字幕 | 久久久久亚洲精品中文字幕 | 亚洲视频五区 |