当前位置: 首页 > Web前端 > JavaScript

Vue3Composable最佳实践(一)

时间:2023-03-26 21:46:18 JavaScript

灏辩洰鍓嶈€岃█锛孋omposable锛堢粍鍚堝嚱鏁帮級搴旇鏄疺UE3搴旂敤绋嬪簭涓粍缁囦笟鍔¢€昏緫鐨勬渶浣虫柟寮忋€傚畠鍏佽鎴戜滑鎻愬彇鍜岄噸鐢ㄥ皬鍧楅€氱敤閫昏緫锛屼娇鎴戜滑鐨勪唬鐮佹洿鏄撲簬缂栧啓銆侀槄璇诲拰缁存姢銆傜敱浜庤繖绉嶇紪鍐橵UE浠g爜鐨勬柟寮忕浉瀵硅緝鏂帮紝鎮ㄥ彲鑳芥兂鐭ラ亾缂栧啓缁勫悎鍑芥暟鐨勬渶浣冲疄璺垫槸浠€涔堬紵鏈郴鍒楁暀绋嬪彲浠ヤ綔涓烘偍鍜屾偍鐨勫洟闃熷湪缁勫悎寮忓紑鍙戣繃绋嬩腑鐨勫弬鑰冩寚鍗椼€傛垜浠皢娑电洊浠ヤ笅鍐呭锛?.濡備綍閫氳繃閫夐」瀵硅薄鍙傛暟浣挎偍鐨勭粍鍚堟洿鍏峰彲閰嶇疆鎬э紱馃憟杩欑瘒鏂囩珷鐨勪富棰?.浣跨敤ref鍜寀nref璁╂垜浠殑鍙傛暟鏇村姞鐏垫椿锛?銆佸浣曡浣犵殑杩斿洖鍊兼洿鏈夌敤锛?銆佷负浠€涔堜粠涓€涓帴鍙e畾涔夊叆鎵嬶紝鍙互璁╀綘鐨勫鍚堝姛鑳芥洿寮哄ぇ锛?.濡備綍鍦ㄦ病鏈夆€滅瓑寰呪€濈殑鎯呭喌涓嬩娇鐢ㄥ紓姝ヤ唬鐮佲€斺€旇浣犵殑浠g爜鏇村鏄撶悊瑙o紱涓嶈繃锛岄鍏堬紝鎴戜滑闇€瑕佺‘淇濇垜浠悊瑙e鍚堝嚱鏁版槸涓€鑷寸殑銆傝鎴戜滑鑺辩偣鏃堕棿瑙i噴浠€涔堟槸缁勫悎鍑芥暟銆備粈涔堟槸Composable-鍙粍鍚堝嚱鏁帮紵鏍规嵁瀹樻柟鏂囨。锛屽湪Vue搴旂敤鐨勬蹇典腑锛屸€滃鍚堝嚱鏁扳€濇槸浣跨敤Vue鐨勭粍鍚圓PI鏉ュ皝瑁呭拰澶嶇敤鏈夌姸鎬侀€昏緫鐨勫嚱鏁般€傝繖鎰忓懗鐫€浠讳綍浣跨敤鍙嶅簲寮忓鐞嗙殑鏈夌姸鎬侀€昏緫閮藉彲浠ヨ浆鎹负澶嶅悎鍑芥暟銆傝繖鍜屾垜浠钩鏃跺皝瑁呭嚭鏉ョ殑鍏叡鏂规硶鏈変簺鍖哄埆銆傛垜浠皝瑁呯殑鍏叡鏂规硶閫氬父鏄棤鐘舵€佺殑锛氬畠鍦ㄦ帴鏀跺埌涓€浜涜緭鍏ュ悗绔嬪嵆杩斿洖鎵€闇€鐨勮緭鍑恒€傚鍚堝嚱鏁伴€氬父涓庣姸鎬侀€昏緫鐩稿叧鑱斻€傛垜浠潵鐪嬬湅瀹樻柟鐨勭粍鍚堝嚱鏁皍seMouse锛歩mport{ref,onMounted,onUnmounted}from'vue'//鎸夌収绾﹀畾锛岀粍鍚堝嚱鏁板悕浠モ€渦se鈥濆紑澶磂xportfunctionuseMouse(){//缁勫悎灏佽鐨勭姸鎬佸拰鐢卞鍚堝嚱鏁扮鐞哻onstx=ref(0)consty=ref(0)//澶嶅悎鍑芥暟鍙互闅忔椂鏇存敼鍏剁姸鎬併€俧unctionupdate(event){x.value=event.pageXy.value=event.pageY}//缁勫悎鍑芥暟涔熷彲浠ラ檮鍔犲埌瀹冩墍灞炵粍浠剁殑鐢熷懡鍛ㄦ湡//鏉ュ惎鍔ㄥ拰鍗歌浇鍓綔鐢╫nMounted(()=>window.addEventListener('mousemove',update))onUnmounted(()=>window.removeEventListener('mousemove',update))//閫氳繃杩斿洖鍊兼毚闇叉墭绠$姸鎬乺eturn{x,y}}鎴戜滑灏嗙姸鎬佸畾涔変负refs锛屾垜浠細鍦ㄩ紶鏍囩Щ鍔ㄦ椂鏇存柊姝ょ姸鎬併€傞€氳繃杩斿洖x鍜寉锛屾垜浠彲浠ュ湪浠讳綍缁勪欢涓娇鐢ㄥ畠浠紝鐢氳嚦鍙互宓屽澶氫釜澶嶅悎鍑芥暟銆傚綋鎴戜滑鍦ㄧ粍浠朵腑浣跨敤濡傛偍鎵€瑙侊紝鎴戜滑鍙互閫氳繃浣跨敤useMouse杞绘澗鍦伴噸鐢ㄦ閫昏緫銆傚彧闇€瑕佸緢灏戠殑浠g爜锛屾垜浠氨鍙互鑾峰彇鍒扮粍浠朵腑鐨勯紶鏍囧潗鏍囩姸鎬併€傜幇鍦ㄦ垜浠澶嶅悎鍑芥暟鏈変簡鐩稿悓鐨勭悊瑙o紝璁╂垜浠湅涓€涓嬬涓€绉嶅彲浠ュ府鍔╂垜浠啓鍑烘洿濂界殑澶嶅悎鍑芥暟鐨勬柟娉曘€傞€夐」瀵硅薄鍙傛暟澶у鏁板鍚堝嚱鏁伴兘鏈変竴涓垨涓や釜蹇呴渶鍙傛暟锛岀劧鍚庢槸涓€绯诲垪鍙€夊弬鏁颁互甯姪杩涜涓€浜涢澶栫殑閰嶇疆銆傚湪閰嶇疆澶嶅悎鍑芥暟鏃讹紝鎴戜滑鍙互灏嗕竴绯诲垪鍙€夐厤缃斁鍏ヤ竴涓€夐」瀵硅薄鍙傛暟涓紝鑰屼笉鏄竴闀夸覆鍙傛暟銆?/浣跨敤閫夐」瀵硅薄鍙傛暟褰㈠紡consttitle=useTitle('Anewtitle',{titleTemplate:'>>%s<<'});//Titleisnow">>Anewtitle<<"//浣跨敤multipleParameterformconsttitle=useTitle('Anewtitle','>>%s<<');//Titlenow">>Anewtitle<<"閫夐」瀵硅薄鍙傛暟褰㈠紡鍙互缁欐垜浠甫鏉ヤ竴浜涙柟渚匡細棣栧厛锛屾垜浠笉蹇呰浣忓弬鏁扮殑姝g‘椤哄簭锛屽挨鍏舵槸鍦ㄥ弬鏁板緢澶氱殑鎯呭喌涓嬨€傝櫧鐒舵垜浠幇鍦ㄥ彲浠ラ€氳繃Typescript鍜宔ditorhints鏉ラ伩鍏嶈繖绉嶉棶棰橈紝浣嗘槸杩欑鏂瑰紡杩樻槸鏈夊尯鍒殑銆傚浜嶫avascript瀵硅薄锛屽弬鏁扮殑椤哄簭灏变笉閭d箞閲嶈浜嗐€傦紙褰撶劧杩欎篃闇€瑕佹垜浠殑鍑芥暟瀹氫箟闇€瑕佹槑纭紝鍚庨潰鍐嶈锛夌浜岋紝浠g爜鐨勫彲璇绘€ф洿寮猴紝鍥犱负鎴戜滑鐭ラ亾option鏄共浠€涔堢殑銆傜涓夛紝浠g爜鏇村叿鍙墿灞曟€э紝浣垮緱浠ュ悗娣诲姞鏂伴€夐」鍙樺緱鏇村姞瀹规槗銆傝繖鏃㈤€傜敤浜庡悜缁勫悎鍑芥暟鏈韩娣诲姞鏂伴€夐」锛屼篃閫傜敤浜庡祵濂楁椂鐨勫弬鏁颁紶閫掋€傚洜姝わ紝浣跨敤瀵硅薄鍙傛暟鏄瘮杈冨弸濂界殑锛屼絾鏄垜浠浣曞疄鐜板憿锛熷鍚堝嚱鏁颁腑鐨勫疄鐜扮幇鍦ㄨ鎴戜滑鐪嬬湅濡備綍鍦ㄥ鍚堝嚱鏁颁腑浣跨敤閫夐」瀵硅薄鍙傛暟銆傝鎴戜滑瀵逛笂闈㈢殑useMouse鍋氫竴浜涙墿灞曪細//...};useMouse鏈韩鏄笉鐢ㄤ紶鍙傛暟鐨勶紝鎵€浠ユ垜浠洿鎺ョ粰瀹冨姞涓€涓猳ptions鍙傛暟锛岃繘琛屼竴浜涢澶栫殑閰嶇疆銆傞€氳繃瑙f瀯锛屾垜浠彲浠ヨ闂墍鏈夌殑鍙€夊弬鏁帮紝骞朵负姣忎釜鍙傛暟璁剧疆涓€涓粯璁ゅ€硷紝閬垮厤浜嗕竴浜涗笉闇€瑕侀澶栭厤缃殑璋冪敤涓嶄紶鍏ュ彲閫夊弬鏁般€備笅闈㈡垜浠湅鐪媀ueUse涓婇潰鐨勪袱涓鍚堝嚱鏁版槸濡備綍浣跨敤杩欎釜妯″紡鐨勩€俈ueUse鏄疺ue3缁勫悎鍔熻兘鐨勯€氱敤宸ュ叿闆嗐€傚畠鐨勫垵琛锋槸璁╂墍鏈変笉鏀寔鍝嶅簲寮忕殑JSAPI閮藉彉鎴愬搷搴斿紡鐨勶紝鐪佸幓绋嬪簭鍛樿嚜宸卞啓鐩稿叧浠g爜鐨勯夯鐑︺€傛垜浠厛鐪媢seTitle锛屽啀鐪媢seRefHistory鏄浣曞疄鐜扮殑銆備緥瀛愨€斺€攗seTitleuseTitle鐨勫姛鑳藉緢绠€鍗曪紝灏辨槸鐢ㄦ潵鏇存柊椤甸潰鐨勬爣棰樸€俢onsttitle=useTitle('InitialPageTitle');//Title:"InitialPageTitle"title.value='NewPageTitle';//Title:"NewPageTitle"瀹冭繕鏈夊嚑涓彲閫夊弬鏁帮紝浠ユ柟渚块澶栫殑鐏垫椿鎬?鎴戜滑鍙互灏唗itleTemplate浣滀负妯℃澘浼犲叆锛屽苟浣跨敤observe灏嗗叾璁剧疆涓哄彲瑙傚療鐨勶紙鐢盡utationObserver鍐呴儴瀹炵幇锛夛細consttitle=useTitle('InitialPageTitle',{titleTemplate:'>>%s<<',observe:true,});//Title:">>InitialPageTitle<<"title.value='NewPageTitle';//Title:">>NewPageTitle<<"褰撴垜浠煡鐪嬪畠鐨勬簮鐮佹椂鍙互鐪嬪埌涓嬮潰鐨勫鐞唀xportfunctionuseTitle(newTitle,options){const{document=defaultDocument,observe=false,titleTemplate='%s',}=options;//...}useTitle鍖呭惈涓€涓繀椤讳紶閫掔殑鍙傛暟鍜屼竴涓彲閫夌殑鍙傛暟瀵硅薄銆傛濡傛垜浠笂闈㈡墍鎻忚堪鐨勶紝瀹冩鏄牴鎹繖涓ā寮忔潵瀹炵幇鐨勩€傛帴涓嬫潵锛岃鎴戜滑鐪嬬湅鏇村鏉傜殑澶嶅悎鍑芥暟濡備綍浣跨敤閫夐」瀵硅薄妯″紡銆傜ず渚?useRefHistoryuseRefHistory鍙互甯姪鎴戜滑璺熻釜瀵瑰弽搴斿彉閲忕殑鎵€鏈夋洿鏀癸紝浣挎垜浠兘澶熻交鏉惧湴鎵ц鎾ゆ秷鍜屾仮澶嶆搷浣溿€?/璁剧疆璁℃暟ref骞惰窡韪畠constcount=ref(0);const{undo}=useRefHistory(count);//澧炲姞countcount.value++;//娉ㄩ攢璁℃暟锛屾挙娑堝苟鍐嶆璁板綍console.log锛堣鏁板櫒鍊硷級锛?/1鎾ら攢();鎺у埗鍙版棩蹇楋紙璁℃暟鍣ㄥ€硷級锛?/0瀹冩敮鎸佽缃緢澶氫笉鍚岀殑閰嶇疆閫夐」{deep:false,flush:'pre',capacity:-1,clone:false,//...}濡傛灉浣犳兂鐭ラ亾杩欎簺閫夐」鍙傛暟鐨勫畬鏁村垪琛ㄤ互鍙婄浉搴旂殑鍔熻兘锛屽ぇ瀹跺彲浠ユ煡闃呯浉鍏虫枃妗o紝杩欓噷涓嶅啀璧樿堪銆傛垜浠彲浠ュ皢閫夐」瀵硅薄浣滀负绗簩涓弬鏁颁紶閫掞紝浠ヨ繘涓€姝ラ厤缃缁勫悎鍑芥暟鐨勮涓猴紝涓庢垜浠笂涓€涓ず渚嬬浉鍚岋細=閫夐」锛?/...}鎴戜滑鍙互鐪嬪埌鍐呴儴鍙В鏋勪簡閮ㄥ垎鍙傛暟鍊笺€傝繖鏄洜涓簎seRefHistory鍐呴儴渚濊禆浜庣粍鍚堝嚱鏁皍seManualHistory锛屽叾浠杘ption鍙傛暟鍚庨潰浼氶€忎紶缁檜seManualHistory鍋氫竴娆″睍寮€鍚堝苟銆?/...constmanualHistory=useManualRefHistory(source,{//灏嗛€夐」瀵硅薄浼犻€掔粰鍙︿竴涓彲缁勫悎...options,clone:options.clone||deep,setSource,},);//...杩欎篃鍜屾垜浠墠闈㈣鐨勪竴鑷达細缁勫悎鍑芥暟鏄彲浠ュ祵濂楃殑銆傛€荤粨鏈枃鏄€婄粍鍚堝嚱鏁版渶浣冲疄璺点€嬬殑绗竴绡囥€傛垜浠爺绌朵簡濡備綍閫氳繃閫夐」瀵硅薄鍙傛暟澧炲姞澶嶅悎鍑芥暟鐨勭伒娲绘€с€傛棤闇€鎷呭績鍙傛暟椤哄簭涓嶆纭甫鏉ョ殑闂锛岄厤缃」鍙互鐏垫椿娣诲姞鍜屾墿灞曘€傛垜浠笉浠呯爺绌朵簡妯″紡鏈韩锛岃繕瀛︿範浜嗗浣曢€氳繃VueUse涓殑useTitle鍜寀seRefHistory鏉ュ疄鐜拌繖涓ā寮忋€傚畠浠暐鏈変笉鍚岋紝浣嗘ā寮忔湰韬緢绠€鍗曪紝鎴戜滑鍙互鐢ㄥ畠鍋氱殑浜嬫儏鏄湁闄愮殑銆傚湪涓嬩竴绡囨枃绔犱腑锛屾垜浠皢浠嬬粛濡備綍閫氳繃ref鍜寀nref浣挎垜浠殑鍙傛暟鏇寸伒娲?/濡傛灉鎴戜滑缁欏畠涓€涓猺ef鎴戜滑宸茬粡鏈変簡constcountRef=ref(2);useCount(countRef);//濡傛灉鎴戜滑缁欏畠涓€涓猺ef涔熷彲浠ョ粰瀹冧竴涓暟瀛梒onstcountRef=useRef(2);杩欏鍔犱簡鐏垫椿鎬э紝骞跺厑璁告垜浠湪搴旂敤绋嬪簭涓殑鏇村鎯呭喌涓嬩娇鐢ㄦ垜浠殑缁勫悎銆?/p>