鏈枃鐨勬€濊矾鏉ユ簮浜庡瀹為檯椤圭洰閲嶆瀯鐨勬€荤粨銆傛杩庢寚姝e拰浜ゆ祦銆傚鏋滃鎮ㄦ湁甯姪锛岃鐐硅禐馃憤鏀惰棌鏀寔銆傛渶杩戦噸鏋勪簡涓€涓€侀」鐩紝鍙戠幇澶勭悊璇锋眰鐨勬嫤鎴櫒姣旇緝涔憋紝浜庢槸閲嶆瀯浜嗘暣涓」鐩殑璇锋眰澶勭悊灞傦紝鐩墠鍦ㄩ」鐩腑杩愯姝e父銆傛湰鏂囧皢涓庡ぇ瀹跺垎浜垜鐨勯噸鏋勬€濊矾鍜屽悗缁殑浼樺寲鎬濊矾銆備负浜嗘柟渚垮垎浜粰澶у锛屾垜浣跨敤Vue3瀹炵幇浜嗕竴涓畝鍗曠殑demo銆傛兂娉曟槸涓€鏍风殑銆傛湁鍏磋叮鐨勬湅鍙嬪彲浠ュ埌鎴戠殑Github涓婃煡鐪嬨€傛湰鏂囧皢浠ヨ繖涓猇ue瀹炵幇鐨刣emo涓轰緥杩涜浠嬬粛銆傚湪鏈枃涓紝鎴戝皢涓昏涓庡ぇ瀹跺垎浜互涓嬪嚑鐐癸細闂鍒嗘瀽涓庢柟妗堣璁★紱閲嶆瀯鍚庣殑鏁堟灉锛涘紑鍙戣繃绋嬶紱鍚庢湡浼樺寲鐐癸紱濡傛灉浣犺繕涓嶇煡閬撲粈涔堟槸HTTP璇锋眰鍜屽搷搴旀嫤鎴櫒锛屽彲浠ュ厛鐪嬬湅銆備竴銆侀渶姹傛€濈淮涓庣▼搴忚璁?銆侀棶棰樺垎鏋愮洰鍓嶈€侀」鐩凡缁忔湁寰堝鍚屼簨寮€鍙戜簡銆傝鎷︽埅鍣ㄥ瓨鍦ㄤ互涓嬮棶棰橈細浠g爜娣蜂贡锛屽彲璇绘€у樊锛涘悇涓嫤鎴櫒鑱岃矗娣蜂贡锛岀浉浜掍緷璧栵紱瀛樺湪閫昏緫闂锛涘洟闃熷唴涓嶅悓椤圭洰鏃犳硶澶嶇敤锛?銆佹柟妗堣璁$粡杩囧垎鏋愪互涓婇棶棰橈紝鎴戠殑鍒濇鏂规鏄細鍙傝€冩彃浠舵灦鏋勮璁★紝灏嗗悇涓嫤鎴櫒鍒嗙锛屽皢鍚勪釜鎷︽埅鍣ㄥ垎绂诲埌涓€涓崟鐙殑鏂囦欢涓繘琛岀淮鎶ゃ€傝亴璐e崟涓€锛岀劧鍚庨€氳繃鎷︽埅鍣ㄨ皟搴﹀櫒杩涜璋冨害鍜屾敞鍐屻€傛嫤鎴櫒璋冨害娴佺▼濡備笅鍥炬墍绀猴細2.閲嶆瀯鍚庢晥鏋滀唬鐮佸叾瀹炴瘮杈冪畝鍗曘€傚厛鏉ョ湅鐪嬫渶缁堢殑瀹炵幇鏁堟灉锛?銆佺洰褰曞眰娆℃洿鍔犳竻鏅般€傞噸鏋勫悗锛岃姹傚鐞嗗眰鐨勭洰褰曞眰娆℃洿鍔犳竻鏅帮紝澶ц嚧濡備笅锛?.鎷︽埅鍣ㄥ紑鍙戯紝鏇存柟渚垮悗缁笟鍔″紑鍙戞柊鐨勬嫤鎴櫒銆傚彧闇€瑕?姝ュ氨鍙互瀹屾垚鎷︽埅鍣ㄧ殑寮€鍙戝拰浣跨敤銆傛嫤鎴櫒璋冨害鍣ㄤ細鑷姩璋冪敤鎵€鏈夌殑鎷︽埅鍣細3.姣忎釜鎷︽埅鍣ㄨ亴璐e鍗曚竴銆佸彲鎻掓嫈姣忎釜鎷︽埅鍣ㄩ兘鎶芥垚涓€涓枃浠舵潵瀹炵幇锛岃姣忎釜鎷︽埅鍣ㄧ殑鑱岃矗鍒嗙銆佸崟涓€銆傚綋涓嶉渶瑕佹煇涓嫤鎴櫒鏃讹紝鍙互闅忔椂鏇存崲锛屾彃鎷旂伒娲汇€?.寮€鍙戣繃绋嬭繖閲屾槸鎴戝崟鐙彁鍙栫殑demo宸ョ▼鐨勪緥瀛愩€?.鍒濆鍖栫洰褰曠粨鏋勬牴鎹墠闈㈢殑璁捐锛岄鍏堥渶瑕佸湪椤圭洰涓垱寤轰竴涓洰褰曠粨鏋勶細-request-index.js//鎷︽埅鍣ㄨ皟搴﹀櫒-interceptors-request//鐢ㄤ簬瀛樻斁姣忎釜璇锋眰鎷︽埅鍣?index.js銆俲s//绠$悊鎵€鏈夌殑璇锋眰鎷︽埅鍣ㄥ苟鎺掑簭-response//鐢ㄦ潵瀛樻斁姣忎釜鍝嶅簲鎷︽埅鍣?index.js//绠$悊鎵€鏈夌殑鍝嶅簲鎷︽埅鍣ㄥ苟鎺掑簭2.瀹氫箟鎷︽埅鍣ㄨ皟搴﹀櫒鍥犱负椤圭洰浣跨敤浜哸xios璇锋眰搴擄紝鎵€浠ユ垜浠渶瑕佹兂鐭ラ亾axios鎷︽埅鍣ㄧ殑浣跨敤鏂规硶锛岃繖閲岀畝鍗曠湅涓媋xios鏂囨。涓婃嫤鎴櫒鐨勪娇鐢ㄦ柟娉曪細//娣诲姞璇锋眰鎷︽埅鍣╝xios.interceptors.request.use(function(config){//涓氬姟閫昏緫returnconfig;},function(error){//涓氬姟閫昏緫returnPromise.reject(error);});//娣诲姞鍝嶅簲鎷︽埅鍣╝xios.interceptors.response.use(function(response){//涓氬姟閫昏緫returnresponse;},function(error){//涓氬姟閫昏緫returnPromise.reject(error);});浠庝笂闈㈢殑浠g爜鎴戜滑鍙互鐭ラ亾锛屽湪浣跨敤鎷︽埅鍣ㄧ殑鏃跺€欙紝鎴戜滑鍙渶瑕佸湪axios.interceptors瀵硅薄涓婅皟鐢ㄧ浉搴旂殑鏂规硶鍗冲彲锛屾墍浠ユ垜浠彲浠ユ彁鍙栧嚭杩欐閫昏緫锛?/src/request/interceptors/index.jsimport{log}鏉ヨ嚜'../鏃ュ織'锛涗粠'./request/index'瀵煎叆璇锋眰锛涗粠'./response/index'瀵煎叆鍝嶅簲锛沞xportconstrunInterceptors=instance=>{log('[runInterceptors]',instance);濡傛灉锛堬紒瀹炰緥锛夎繑鍥?//涓?constkeyinrequest)璁剧疆璇锋眰鎷︽埅鍣▄instance.interceptors.request.use(config=>request[key](config));}//璁剧疆鍝嶅簲鎷︽埅鍣╢or(constkeyinresponse){instance.interceptors.response.use(result=>response[key](result));}returninstance;}杩欐槸鎴戜滑鐨勬牳蹇冩嫤鎴櫒璋冨害鍣ㄣ€傚鍏ユ墍鏈夎姹傛嫤鎴櫒鍜屽搷搴旀嫤鎴櫒鍚庯紝閫氳繃for寰幆锛屾敞鍐屾墍鏈夋嫤鎴櫒锛屾渶鍚庤繑鍥炴暣涓猘xios瀹炰緥3.瀹氫箟绠€鍗曠殑璇锋眰鎷︽埅鍣ㄥ拰鍝嶅簲鎷︽埅鍣ㄨ繖閲屾垜浠仛涓€涓畝鍗曠殑婕旂ず锛屽垱寤哄涓嬩袱涓嫤鎴櫒锛氳姹傛嫤鎴櫒锛歴etLoading锛岀敤浜庡湪鍙戣捣璇锋眰鍓嶏紝鏄剧ず涓€涓叏灞€鐨凾oast妗嗭紝鎻愮ず鈥淟oading...鈥濇枃瀛椼€傚搷搴旀嫤鎴櫒锛歴etLoading锛屼綔鐢ㄦ槸璇锋眰鍝嶅簲鍚庡叧闂〉闈腑鐨凾oast妗嗐€備负浜嗙粺涓€寮€鍙戣鑼冿紝鎴戜滑绾﹀畾鎻掍欢寮€鍙戣鑼冨涓嬶細;//鎷︽埅鍣ㄤ笟鍔¤繑鍥為€夐」;};exportdefaultinterceptorName;棣栧厛鍒涘缓鏂囦欢src/request/interceptors/request/锛屽湪鐩綍涓嬪垱寤簊etLoading.js鏂囦欢銆傛牴鎹笂闈㈢害瀹氱殑鎻掍欢寮€鍙戣鑼冿紝鎴戜滑瀹屾垚濡備笅鎻掍欢寮€鍙戯細//src/request/interceptors/request/setLoading.jsimport{Toast}from'vant';import{log}from"../../log";/*鎷︽埅鍣ㄥ悕绉帮細鍏ㄥ眬璁剧疆璇锋眰鐨勫姞杞藉姩鐢?/constsetLoading=options=>{log("[interceptor.request]setLoading:",options);Toast.loading({duration:0,message:'Loading...',forbidClick:true,});杩斿洖閫夐」锛泒锛涘鍑洪粯璁よ缃姞杞斤紱鐒跺悗export灏嗚姹傛嫤鎴櫒瀵煎嚭涓烘暟缁勶紝鏂逛究鎷︽埅鍣ㄨ皟搴﹀櫒缁熶竴娉ㄥ唽锛?/src/request/interceptors/request/index.jsimportsetLoadingfrom'./setLoading';瀵煎嚭榛樿鍊糩setLoading]锛涘悓鏍风殑锛屾垜浠紑鍙戜竴涓搷搴旀嫤鎴櫒锛?/src/request/interceptors/response/setLoading.jsimport{Toast}from'vant';浠庘€?./../log鈥濆鍏log}锛?*鎷︽埅鍣ㄥ悕绉?off鍏ㄥ眬璇锋眰鍔犺浇鍔ㄧ敾*/constsetLoading=result=>{log("[interceptor.response]setLoading:",result);//绀轰緥锛氬綋璇锋眰鎴愬姛杩斿洖鏃讹紝鍏抽棴鎵€鏈塼oast妗唅f(result&&result.success){Toast.clear();}returnresult;};exportdefaultsetLoading;瀵煎嚭鍝嶅簲鎷︽埅鍣細//src/request/interceptors/response/index.jsimportsetLoadingfrom'./setLoading';exportdefault[setLoading];4銆佸叏灞€璁剧疆axios鎷︽埅鍣ㄥ拰涔嬪墠涓€鏍凤紝鎴戝張鍐欎簡鍑犱釜鎷︽埅鍣細璇锋眰鎷︽埅鍣細setSecurityInformation.js锛氬湪璇锋眰鐨剈rl涓坊鍔犲畨鍏ㄥ弬鏁帮紱setSignature.js锛氬湪璇锋眰澶翠腑娣诲姞绛惧悕淇℃伅锛泂etToken.js锛氬湪璇锋眰鐨刄RL涓坊鍔犵鍚嶄俊鎭紝鍦ㄨ姹傚ご涓坊鍔爐oken淇℃伅锛涘搷搴旀嫤鎴櫒锛歴etError.js锛氬鐞嗗搷搴旂粨鏋滅殑閿欒锛屾瘮濡傚叧闂墍鏈塼oast妗嗭紱setInvalid.js锛氬鐞嗗搷搴旂粨鏋滅殑鐧诲綍澶辫触锛屾瘮濡傝烦杞埌鐧诲綍椤甸潰锛泂etResult.js锛氬鐞嗗搷搴旂粨鏋滄暟鎹祵濂楄繃娣辩殑闂锛屽皢result.data.data.data绛夎繑鍥炵粨鏋滃鐞嗘垚result.data鏍煎紡锛涜嚦浜庡浣曞疄鐜帮紝鏈夊叴瓒g殑鍙互鍘绘垜鐨凣ithub鐪嬬湅鐒跺悗鎴戜滑鍙互閲嶆柊鎵撳寘axios锛屽鍑簉equest瀵硅薄渚涗笟鍔′娇鐢細//src/request/index.jsimportaxiosfrom'axios';import{runInterceptors}from'./interceptors/index';exportconstrequestConfig={timeout:10000};letrequest=axios.create(requestConfig);request=runInterceptors(request);瀵煎嚭榛樿璇锋眰锛涘湪杩欓噷瀹屾垚銆備笟鍔′腑闇€瑕佸彂璧疯姹傦紝鍙互杩欐牱浣跨敤锛?template>
5.娴嬭瘯寮€鍙戯紝瀹冨氨蹇埌浜嗐€傛垜浠彂閫佷竴涓姹傦紝鍙互鐪嬪埌鎵€鏈夋嫤鎴櫒鐨勬墽琛岃繃绋嬪涓嬶細鏌ョ湅璇锋眰澶翠俊鎭細鍙互鐪嬪埌鎴戜滑寮€鍙戠殑璇锋眰鎷︽埅鍣ㄥ凡缁忕敓鏁堜簡銆?.鍦═aro涓娇鐢ㄧ敱浜嶵aro宸茬粡鎻愪緵浜員aro.request鏂规硶浣滀负璇锋眰鏂规硶锛屾垜浠氨涓嶉渶瑕佷娇鐢╝xios鏉ュ彂閫佽姹備簡銆傚熀浜庝互涓婁唬鐮佺殑鏀归€犱篃寰堢畝鍗曪紝鍙渶瑕佹敼2涓湴鏂癸細1銆佷慨鏀瑰皝瑁呰姹傜殑鏂规硶涓昏鏄皢axios鏇挎崲涓篢aro.request鏂规硶锛屼娇鐢╝ddInterceptor鏂规硶寮曞叆鎷︽埅鍣細//婧?璇锋眰/绱㈠紩銆俲simportTarofrom"@tarojs/taro";import{runInterceptors}from'./interceptors/index';Taro.addInterceptor(runInterceptors);exportconstrequest=Taro.request;exportconstrequestTask=Taro.RequestTask;//鐪嬮渶姹傦紝鏄惁闇€瑕乪xportconstaddInterceptor=Taro.addInterceptor;//鏍规嵁闇€姹傦紝鏄惁闇€瑕?.淇敼鎷︽埅鍣ㄨ皟搴﹀櫒鐢变簬axios鍜孴aro.request娣诲姞鎷︽埅鍣ㄧ殑鏂瑰紡涓嶅悓锛屾墍浠ヤ篃闇€瑕佹浛鎹細importrequestfrom'./interceptors/request';importresponsefrom'./interceptors/response';exportconstinterceptor={request,response};exportconstgetInterceptor=(chain={})=>{//璁剧疆璇锋眰鎷︽埅鍣╨etrequestParams=chain.璇锋眰鍙傛暟锛沠or(constkeyinrequest){requestParams=request[key](requestParams);}//璁剧疆鍝嶅簲鎷︽埅鍣╨etresponseObject=chain.proceed(requestParams);for(constkeyinresponse){responseObject=responseObject.then(res=>response[key](res));}鍥炲鐡畆esponseObject;};鍏蜂綋API鍙互鍙傝€僒aro.request鏂囨。锛岃繖閲屽彧鏄◢寰粙缁嶄竴涓嬨€備簲銆侀」鐩€荤粨涓庢€濊€冨彲浠ヤ紭鍖栫殑鐐瑰緢澶氥€傜洰鍓嶆垜鎯冲埌鐨勮繖浜涳紝涔熺畻鏄垜鐨凾ODOLIST涔嬩竴锛?.鎶婅姹傚眰鍒嗙鎴愪竴涓簱銆傜敱浜庡叕鍙哥幇鍦ㄦ湁寰堝鐙珛绔欑偣鐨勯」鐩紝鑰冭檻鍒伴」鐩殑缁熶竴寮€鍙戣鑼冿紝鍙互鑰冭檻灏嗚姹傚眰浣滀负绉佹湁搴撶嫭绔嬬淮鎶ゃ€傜洰鍓嶆€濊矾锛氬弬鑰冩彃浠舵灦鏋勮璁★紝閫氳繃lerna绠$悊鎵€鏈夋嫤鎴櫒锛涘崌绾ypeScript锛屾柟渚跨鐞嗗拰寮€鍙戯紱杩涜宸ョ▼鍖栨敼閫狅紝娣诲姞鏋勫缓宸ュ叿銆佸崟鍏冩祴璇曘€乁MD绛夛紱瀹屽杽浣跨敤鍜屽紑鍙戞枃妗c€?.鏀寔鍙浛鎹㈢殑璇锋眰搴撱€傝繖鏄洜涓烘垜浠墠绔洟闃熺洰鍓嶄娇鐢ㄧ殑璇锋眰搴撹緝澶氾紝姣旇緝鍒嗘暎銆傚洜姝わ紝鑰冭檻鍒伴€氱敤鎬э紝闇€瑕佸鍔犲鍙浛鎹㈣姹傚簱鏂规硶鐨勬敮鎸併€傜洰鍓嶆€濊矾锛氬湪鐜版湁鐨勮姹傚眰涓婃娊璞″嚭涓€灞傝姹傚簱閫傞厤灞傦紝瀹氫箟缁熶竴鐨勬帴鍙o紱鍐呯疆閫傞厤鍑犵甯哥敤璇锋眰搴撱€?銆佸紑鍙戞嫤鎴櫒鑴氭墜鏋剁殑鐩殑鍏跺疄寰堢畝鍗曘€傝鍥㈤槦鍏朵粬浜虹洿鎺ヤ娇鐢ㄨ剼鎵嬫灦宸ュ叿鏍规嵁鍐呯疆鐨勮剼鎵嬫灦妯℃澘蹇€熷垱寤烘嫤鎴櫒杩涜鍚庣画寮€鍙戯紝寰堝ぇ绋嬪害涓婄粺涓€浜嗘嫤鎴櫒鐨勫紑鍙戣鑼冦€傜洰鍓嶆€濊矾锛氬唴缃袱濂楁嫤鎴櫒妯℃澘锛氳姹傛嫤鎴櫒鍜屽搷搴旀嫤鎴櫒锛涜剼鎵嬫灦寮€鍙戠浉瀵圭畝鍗曪紝鍙傛暟锛堝璇█锛夋牴鎹笟鍔¢渶瑕佺‘瀹氥€?.澧炲己鐨勬嫤鎴櫒璋冨害鐩墠杩欎釜鍔熻兘鐨勫疄鐜版瘮杈冪畝鍗曪紝杩樻槸瑕佽€冭檻澧炲己鎷︽埅鍣ㄨ皟搴︺€傚綋鍓嶆€濊矾锛氬鐞嗘嫤鎴櫒鏁呴殰锛涘鐞嗘嫤鎴櫒璋冨害椤哄簭锛涙嫤鎴櫒鍚屾鎵ц銆佸紓姝ユ墽琛屻€佸苟鍙戞墽琛屻€佸惊鐜墽琛岀瓑锛涘彲鎻掓嫈鎷︽埅鍣ㄨ皟搴︼紱鑰冭檻鍙傝€僒apable鎻掍欢鏈哄埗锛涘叚銆佹湰鏂囨€荤粨鏈枃閫氳繃涓€涓畝鍗曠殑椤圭洰閲嶆瀯锛屾€荤粨浜嗕竴涓姹傚眰鎷︽埅鍣ㄨ皟搴︽柟妗堬紝鐩殑鏄疄鐜版墍鏈夋嫤鎴櫒鑱岃矗鍗曚竴锛屾柟渚跨淮鎶わ紝缁熶竴缁存姢鑷姩璋冨害锛屽ぇ澶у噺灏戝疄闄呬笟鍔$殑寮€鍙戞嫤鎴櫒闅惧害銆備互鍚庢垜杩樻湁寰堝鍦版柟闇€瑕佷紭鍖栥€備綔涓鸿嚜宸辩殑涓€涓猅ODOLIST锛屽鏋滃仛鐨勫畬鍏ㄧ缁燂紝瀹氫綅鍙兘浼氭洿鍋忓悜浜庢嫤鎴櫒璋冨害瀹瑰櫒銆傚彧鎻愪緵浜嗕竴浜涢€氱敤鐨勬嫤鎴櫒锛屽叾浣欑殑杩樻槸鐢卞紑鍙戣€呰嚜琛屽畾涔夈€俵ibrary璐熻矗璋冨害锛屼絾鏄父鐢ㄧ殑requestlibraries涓€鑸兘鍑嗗濂戒簡锛屾墍浠ラ渶瑕佹潈琛¤繖鏍峰仛鐨勪环鍊笺€傚綋鐒剁洰鍓嶈繕鏄洿鍠滄浣滀负鍥㈤槦鍐呴儴鐨勭鏈夊簱鏉ュ紑鍙戜娇鐢紝鍥犱负鍩烘湰涓婂洟闃熷唴閮ㄤ娇鐢ㄧ殑涓氬姟閮藉樊涓嶅锛屽彧鏄」鐩笉鍚岃€屽凡銆?/p>