您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“如何以go思想去處理js異常拋棄trycatch”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何以go思想去處理js異常拋棄trycatch”吧!
通常情況下 錯(cuò)誤處理的方式無非不過兩種
泛處理
精處理
其實(shí)都很好理解
// 偽代碼 try { const file = await readFile('../file') const content = filterContent(file) } catch (e) { alert('xxxx',e.msg) }
泛處理指的是對所有可能的錯(cuò)誤都使用相同的處理方式,比如在代碼中使用相同統(tǒng)一的錯(cuò)誤提示信息
這種方式適用于一些簡單的,不太可能發(fā)生的錯(cuò)誤,不如文件不存在,網(wǎng)絡(luò)連接超時(shí)等。
對于更加復(fù)雜的錯(cuò)誤,應(yīng)該使用精處理,即根據(jù)具體情況對不同類型的錯(cuò)誤進(jìn)行特定的處理
const [readErr,readFile] = await readFile('../file') if (readErr) { // 處理讀取錯(cuò)誤 return } const [filterErr,filterContent] = filterContent(readFile) if (filterErr) { // 處理過濾錯(cuò)誤 return }
精處理可以讓我們把控計(jì)劃的每一步,問題也很顯然暴露了出來,過于麻煩
在實(shí)際開發(fā)當(dāng)中,我們需要根據(jù)實(shí)際情況選擇適當(dāng)?shù)姆绞竭M(jìn)行錯(cuò)誤處理。
由于本人是精處理分子,基于此開發(fā)了一個(gè)js
版本的errors
包
import { Errors } from '@memo28/utils' Errors.News('err')
如何給一個(gè)錯(cuò)誤分類
import { Errors } from '@memo28/utils' Errors.News('err', { classify: 1 })
如何判斷兩個(gè)錯(cuò)誤是相同類型
import { Errors } from '@memo28/utils' Errors.As(Errors.News('err', { classify: 1 }), Errors.News('err2', { classify: 1 })) // true Errors.As(Errors.News('err', { classify: 1 }), Errors.News('err2', { classify: 2 })) // false
一個(gè)錯(cuò)誤包含了哪些信息?
Errors.New('as').info() // { msg: 'as' , classify: undefined } Errors.New('as').trace() // 打印調(diào)用棧 Errors.New('as').unWrap() // 'as'
import { AnomalousChain, panicProcessing } from '@memo28/utils' class A extends AnomalousChain { // 定義錯(cuò)誤處理函數(shù), // 當(dāng)每次執(zhí)行的被 panicProcessing 裝飾器包裝過的函數(shù)都會(huì)檢查 是否存在 this.errors 是否為 ErrorsNewResult 類型 // 如果為 ErrorsNewResult 類型則 調(diào)用 panicProcessing的onError回調(diào) 和 skip函數(shù) skip(errors: ErrorsNewResult | null): this { console.log(errors?.info().msg) return this } @panicProcessing() addOne(): this { console.log('run one') super.setErrors(Errors.New('run one errors')) return this } @panicProcessing({ // 在 skip 前執(zhí)行 onError(error) { console.log(error.unWrap()) }, // onRecover 從錯(cuò)誤中恢復(fù), 當(dāng)返回的是true時(shí) 繼續(xù)執(zhí)行addTwo內(nèi)邏輯,反之 // onRecover(erros) { // return true // }, }) addTwo(): this { console.log('run two') return this } } new A().addOne().addTwo() // output run one run one errors // in onError run one errors // in skip fn
到此,相信大家對“如何以go思想去處理js異常拋棄trycatch”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。