当前位置: 首页 > Web前端 > vue.js

2020年关于Vue3你需要了解什么?

时间:2023-04-01 12:45:55 vue.js

浣滆€咃細MattMaribojoc蹇冩€佷汉銆傛湰鏂囧凡鏀跺綍鍒癎itHubhttps://github.com/qq44924588...锛屾枃绔犲凡鍒嗙被锛屼篃鏁寸悊浜嗗緢澶氭垜鐨勬枃妗e拰鏁欑▼璧勬枡銆傚墠绔紑鍙戝伐绋嬪笀蹇呰鐨勪功绫嶆湁鍝簺锛烿ue鏄洰鍓嶅墠娌垮紑鍙戜腑鏈€鐑棬鐨勬鏋朵箣涓€锛?019骞存瘡鍛ㄤ笅杞介噺缈讳簡涓€鐣€?020骞村垵Vue3鐨勫彂甯冧篃灏嗗鍔犲叾鍙楁杩庣▼搴︺€俈ue3涓哄紑鍙戜汉鍛樻彁渚涗簡鏇村鎺у埗鏉冿紝瀹冨厑璁告垜浠簿纭帶鍒堕」鐩腑鍙戠敓鐨勪簨鎯咃紝浠庣紪鍐欒嚜瀹氫箟缂栬瘧鍜屾覆鏌撴柟娉曞埌鐩存帴浣跨敤Vue鍙嶅簲鎬PI銆俈ue3浣跨敤Proxy鏉ョ洃鎺ф暟鎹彉鍖栥€傚搷搴斿紡鏄疺ueJS鐨勬牳蹇冦€傛暟鎹繀椤绘槸鐩稿叧鐨勶紝骞朵笖鍙互瑙傚療鍜屾洿鏂颁互鍝嶅簲浠讳綍鍙樺寲銆俈ue2浣跨敤Object.defineProperty鍒涘缓getter鍜宻etter鏉ュ疄鐜板搷搴斿紡銆備娇鐢∣bject.defineProperty涓昏鏈変袱涓棶棰橈紝瀹樻柟鏂囨。涓湁鎻愬埌锛歏ue鏃犳硶妫€娴嬪埌鏁扮粍鍜屽璞$殑鍙樺寲銆傚浜庡璞★紝Vue鏃犳硶妫€娴嬪睘鎬х殑娣诲姞鎴栧垹闄ゃ€傜敱浜嶸ue鍦ㄥ垵濮嬪寲瀹炰緥鏃朵細瀵瑰睘鎬ц繘琛実etter/setter杞崲锛屽洜姝よ灞炴€у繀椤诲瓨鍦ㄤ簬鏁版嵁瀵硅薄涓婏紝Vue鎵嶈兘灏嗗叾杞崲涓哄搷搴斿紡銆傚浜庢暟缁勶紝Vue鏃犳硶妫€娴嬪埌浠ヤ笅鏁扮粍鐨勫彉鍖栵細褰撲綘浣跨敤绱㈠紩鐩存帴璁剧疆鏁扮粍椤规椂锛屼緥濡傦細vm.items[indexOfItem]=newValue褰撲綘淇敼鏁扮粍鐨勯暱搴︽椂锛屼緥濡傦細vm.items.length=newLength渚嬪渚嬪瓙锛歷arvm=newVue({data:{items:['a','b','c']}})vm.items[1]='x'//娌℃湁鍝嶅簲vm.椤圭洰銆俵ength=2//娌℃湁鍝嶅簲涓轰粈涔堣浣跨敤Proxy锛烿ue3鐨勮В鍐虫柟妗堟槸浣跨敤鍩轰簬Proxy鐨勮瀵熻€呮ā寮忔潵瑙e喅Vue2鍝嶅簲鐨勪竴浜涢檺鍒躲€傛柊鏃х郴缁熺殑涓昏鍖哄埆鍦ㄤ簬锛屽湪Vue2涓紝Object.defineProperty淇敼浜嗗師濮嬫暟鎹紝鑰孭roxy鍒欐病鏈夛紝Proxy灏嗙洰鏍囨暟鎹櫄鎷熷寲骞惰缃簡涓嶅悓鐨刪andlers锛堢О涓簍argets锛夛紝閫氳繃getters鍜宻etters杩涜鎷︽埅鏁版嵁銆倂ue3鎰忓懗鐫€鎴戜滑涓嶉渶瑕佷娇鐢╲m.$set璁╂暟鎹姩鎬佸搷搴旓紝鍚屾椂涔熻В鍐充簡vue2鎿嶄綔鏁扮粍鏃犳硶鍝嶅簲鐨勯棶棰樸€俌ouYuxi鎬荤粨锛屽熀浜巃gent鍙互鏀寔锛氭娴嬪睘鎬у鍒犳娴嬫暟缁勭储寮?闀垮害鍙樺寲鏀寔Map銆丼et銆乄eakMap鍜學eakSetCompositionAPI杩欐槸Vue3鐩墠鏈€澶х殑鍙樺寲锛屾湁鍔╀簬浠g爜缁勭粐鍜屽鐢?鐩墠锛屽湪Vue涓垜浠娇鐢∣ptionsAPI銆侽ptionsAPI鎸夊睘鎬х粍缁囦唬鐮侊細data銆乧omputed銆乵ethods绛夈€傝繖鏄竴绉嶉潪甯哥洿瑙傜殑鏂瑰紡锛屼絾缁存姢涓€浜涘鏉傜殑缁勪欢浼氬彉寰楅潪甯稿洶闅俱€傚崟涓嚱鏁扮殑浠g爜缁忓父琚姏鍦ㄧ浉闅旀暟鐧捐鐨勫涓湴鏂广€傚彲缁存姢鎬у拰鍙鎬ф垚涓轰富瑕佸叧娉ㄧ偣銆傛帴涓嬫潵锛岃鎴戜滑蹇€熶簡瑙d竴涓婥ompositionAPI鐨勫伐浣滃師鐞嗐€俰mport{reactive,computed}from'vue'exportdefault{setup(){letstate=reactive({input:'',groceries:[],groceriesLeft:computed(()=>{groceries.length})})鍑芥暟addGrocery(){state.groceries.push(state.input)state.input=''}functiondeleteGrocery(index){state.groceries.splice(index,1);}return{state,addGrocery,deleteGrocery}}}鎴戜滑鏉ュ垎鏋愪竴涓嬩笂闈㈢殑杩囩▼馃槈import{reactive,computed}from'vue'VueCompositionAPI鏆撮湶浜嗗緢澶歏ue涓殑鏍稿績鍑芥暟锛屾瘮濡俽eactive鍜宑omponent鏂规硶锛屾墍浠ユ垜浠渶瑕佸鍏ヤ粬浠€俥xportdefault{setup(){setup()鏂规硶鐨勫紩鍏ユ槸Vue3涓渶澶х殑鍙樺寲涔嬩竴銆傛湰璐ㄤ笂锛屽畠鍏佽鎴戜滑纭畾浼犲洖缁欐ā鏉跨殑鍐呭锛屼互鍙婅繑鍥炵殑浠讳綍鍐呭閮藉彲浠ュ湪妯℃澘涓闂€傛垜浠彲浠ヨ缃搷搴斿紡鏁版嵁銆佺敓鍛藉懆鏈熴€佽绠楀睘鎬с€佸畾涔夌殑鏂规硶骞惰繑鍥炴垜浠湪璁剧疆涓兂瑕佺殑浠讳綍涓滆タ銆俵etstate=reactive({input:'',groceries:[],groceriesLeft:computed(()=>{groceries.length})})閫氳繃灏嗘墍鏈夎繖浜涙暟鎹寘瑁呭湪鍙嶅簲寮忔柟娉曚腑锛屾墍鏈夋暟鎹皢鍦ㄥ唴閮ㄦ垚涓哄弽搴斿叕寮忋€傛鐘舵€佹ā寮忔潵鑷狢ompositionAPI鏂囨。銆俽eactive()鍑芥暟鎺ュ彈涓€涓璞′綔涓哄弬鏁板苟杩斿洖涓€涓唬鐞嗗璞★紝鎵€鏈夌殑鏁版嵁閮戒細鍦ㄥ唴閮ㄥ彉鎴愬弽搴旀€х殑銆傞渶瑕佹敞鎰忕殑涓€浠朵簨鏄垜浠0鏄巊roceryLeft鍙橀噺鐨勬柟寮忋€傚畠鏄竴涓绠楀睘鎬э紝鍦╯etup()鏂规硶涓畾涔夛紝涓嶅啀鍗曠嫭澹版槑銆俧unctionaddGrocery(){state.groceries.push(state.input)state.input=''}functiondeleteGrocery(index){state.groceries.splice(index,1)}鍑芥暟澹版槑娌℃湁澶ぇ鍙樺寲锛屼笉鍚岀殑鏄敱浜庢墍鏈夌殑鍝嶅簲鏁版嵁閮戒繚瀛樺湪state瀵硅薄涓紝鎵€浠ユ垜浠笉寰椾笉浣跨敤state瀵硅薄杩涜璁块棶锛屼絾杩欏苟涓嶆槸Vue3鐗规湁鐨勩€俽eturn{state,addGrocery,deleteGrocery}鏈€鍚庯紝鎴戜滑甯屾湜浠巗etup()鏂规硶涓繑鍥炶繖浜涘嚱鏁帮紝浠ヤ究鍙互鍦ㄦā鏉垮唴璁块棶澹版槑鐨勬暟鎹拰鏂规硶銆傞娆″紩鍏ヨ繖绉嶆柟娉曟椂锛孷ue绀惧尯涓瓨鍦ㄥ緢澶氬弽瀵规剰瑙侊紝鍥犱负寮€鍙戜汉鍛樹笉鎯宠杩紪鍐欒繖绉嶆柊鏂规硶銆傜劧鑰岋紝杩欎篃鏄彲閫夌殑锛岃繖鎰忓懗鐫€鎴戜滑浠嶇劧鍙互浣跨敤vue2鐨勬柟寮忔潵瀹屾垚瀹冦€係uspense鐜板凡鍦╒ue涓彲鐢⊿uspense鏄疪eact鐨勪竴涓壒鎬э紝宸插湪Vue3涓紩鍏ャ€係uspense浣跨粍浠垛€滅瓑寰呪€濆紓姝ユ搷浣滐紝鐩村埌寮傛鎿嶄綔鍦ㄥ憟鐜颁箣鍓嶅畬鎴愩€傚綋鎴戜滑鎯冲湪setup()鏂规硶涓紓姝ュ姞杞藉唴瀹规椂锛岃繖寰堟湁鐢ㄣ€傜畝鑰岃█涔嬶紝鍙渶鐭ラ亾璁剧疆鏂规硶鍙互鍍忎换浣曞叾浠栨柟娉曚竴鏍峰紓姝ャ€傚鏋滄垜浠兂鍦ㄧ瓑寰呯粍浠惰幏鍙栨暟鎹苟瑙f瀽瀹冩椂鏄剧ず绫讳技鈥淒esperatelyloading...鈥濈殑鍐呭锛屾垜浠彧闇€涓夋鍗冲彲瀹炵幇Suspense銆傚皢寮傛缁勪欢鍖呰鍦?template#default>鏍囩涓湪鎴戜滑鐨勫紓姝ョ粍浠舵梺杈规坊鍔犱竴涓甫鏈夋爣绛?template#fallback>鐨勫悓绾х粍浠躲€備娇鐢ㄦ彃妲藉皢涓や釜缁勪欢鍖呰鍦ㄤ竴涓?suspense>缁勪欢涓紝Suspense灏嗗憟鐜板洖閫€鍐呭锛岀洿鍒伴粯璁ゅ唴瀹瑰噯澶囧氨缁€傜劧鍚庡畠浼氳嚜鍔ㄥ垏鎹㈠埌鏄剧ず鎴戜滑鐨勫紓姝ョ粍浠躲€?Suspense>

鎷煎懡鍔犺浇...
Vue3涓殑Fragment锛屽張涓€涓簿褰╁彟澶栨垜浠彲浠ユ湡寰呯殑鏄疐ragments銆備綘鍙兘浼氶棶锛屼粈涔堟槸鍒嗙墖锛熷鏋滀綘鍒涘缓涓€涓猇ue缁勪欢锛屽畠鍙兘鏈変竴涓牴鑺傜偣銆傝繖鎰忓懗鐫€鎮ㄤ笉鑳藉垱寤哄儚杩欐牱鐨勭粍浠讹紝鍥犱负浠h〃浠讳綍Vue缁勪欢鐨刅ue瀹炰緥闇€瑕佺粦瀹氬埌鍗曚釜DOM鍏冪礌銆傚垱寤哄叿鏈夊涓狣OM鑺傜偣鐨勭粍浠剁殑鍞竴鏂规硶鏄垱寤轰竴涓病鏈夊簳灞俈ue瀹炰緥鐨勫姛鑳界粍浠躲€傚師鏉eact绀惧尯涔熸湁鍚屾牱鐨勯棶棰樸€備粬浠彁鍑虹殑瑙e喅鏂规鏄竴涓悕涓篎ragment鐨勮櫄鎷熷厓绱犮€傚畠鐪嬭捣鏉ュ儚杩欐牱锛殅}铏界劧Fragment鐪嬭捣鏉ュ儚涓€涓櫘閫氱殑DOM鍏冪礌锛屼絾瀹冩槸铏氭嫙鐨勶紝鏍规湰涓嶄細鍦―OM鏍戜腑鍛堢幇銆傝繖鏍锋垜浠氨鍙互灏嗙粍浠跺姛鑳界粦瀹氬埌鍗曚釜鍏冪礌涓紝鑰屾棤闇€鍒涘缓棰濆鐨凞OM鑺傜偣銆傜洰鍓嶏紝鎮ㄥ彲浠ヤ娇鐢╲ue-fragments搴撳湪Vue2涓娇鐢‵ragments锛岃€屽湪Vue3涓紝鎮ㄥ皢鑳藉寮€绠卞嵆鐢紒闂ㄦ埛闂ㄦ埛鏄壒娈婄粍浠讹紝鏃ㄥ湪鍛堢幇褰撳墠缁勪欢涔嬪鐨勫唴瀹广€傝繖涔熸槸React鍘熺敓瀹炵幇鐨勫姛鑳戒箣涓€銆備互涓嬫槸React鏂囨。涓叧浜庨棬鎴风殑鍐呭銆傞棬鎴锋彁渚涗簡涓€绉嶄竴娴佺殑鏂瑰紡鏉ュ皢瀛愯妭鐐规覆鏌撳埌鐖剁粍浠剁殑DOM灞傛缁撴瀯涔嬪鐨凞OM鑺傜偣涓€傝繖鏄鐞嗗嚭鐜板湪椤甸潰椤堕儴鐨勬ā寮忋€佸脊鍑虹獥鍙e拰涓€鑸粍浠剁殑濂芥柟娉曘€傞€氳繃浣跨敤闂ㄦ埛锛屾偍鍙互纭繚涓昏缁勪欢鐨勪换浣旵SS瑙勫垯閮戒笉浼氬奖鍝嶆偍瑕佹樉绀虹殑缁勪欢锛屽苟鐪佸幓浣跨敤z-index杩涜璁ㄥ帉鐨勯粦瀹㈡敾鍑荤殑楹荤儲銆備笅闈㈡槸鏉ヨ嚜Portal-Vue鏂囨。鐨勭ず渚嬪睆骞曟埅鍥惧拰浠g爜銆傚浜庢瘡涓狿ortal锛屾垜浠渶瑕佹寚瀹氬叾鐩爣鐩殑鍦帮紝鍗砅ortal鍐呭灏嗗憟鐜扮殑浣嶇疆銆?template>

鏈涓嬫柟鐨勫唴瀹圭敱PortalVue娓叉煋鍦ㄥ彸/涓嬶紙绾㈣壊锛夊鍣ㄤ腑

杩欐槸鏉ヨ嚜宸︿晶/椤堕儴瀹瑰櫒锛堢豢鑹诧級鐨勫唴瀹广€傛渶妫掔殑鏄紝瀹冭法缁勪欢宸ヤ綔锛屽洜姝ゆ偍鍙互灏嗗唴瀹瑰彂閫佸埌浠讳綍鍦版柟锛?/p>
Vue3浼樺寲娓叉煋鍐呴儴娴嬭瘯琛ㄦ槑锛孷ue3涓殑妯℃澘鏍峰紡閫熷害鎻愬崌浜嗗ぇ绾?20%姣擵ue2銆傛彁鍗嘨ue3娓叉煋閫熷害鐨勫叧閿紭鍖栨湁涓や釜锛欱lockTree浼樺寲锛屾敼杩涢潤鎬佽妭鐐规爲涓嬮潰鍐嶈缁嗕粙缁嶄竴涓嬨€侭lockTree浼樺寲浣跨敤铏氭嫙DOM瀛樺湪鐡堕锛屽洜涓烘瘡涓粍浠堕兘蹇呴』璺熻釜鍏朵緷璧栭」銆傜洃鍚繖浜涗緷璧栭」瑕佹參寰楀锛屽洜涓哄畠浼氶€掑綊鍦版鏌ユ暣涓厓绱犳爲銆俈ue鍥㈤槦娉ㄦ剰鍒扮殑涓€浠朵簨鏄紝鍦ㄧ粍浠朵腑锛屽ぇ澶氭暟鑺傜偣缁撴瀯鏄潤鎬佺殑銆傝€屼笖锛屽鏋滀竴涓儴鍒嗗疄闄呬笂鏄姩鎬佺殑锛堢敱浜巚-if鎴杤-for鎸囦护锛夛紝瀹冪殑璁稿鍐呭閮芥槸闈欐€佺殑銆傚埄鐢ㄨ繖涓€濇兂锛孷ue3灏嗘ā鏉垮垎涓洪潤鎬佸拰鍔ㄦ€侀儴鍒嗐€傜幇鍦ㄦ覆鏌撳櫒鐭ラ亾鍝簺鑺傜偣鏄姩鎬佺殑锛屽畠涓嶄細娴垂鏃堕棿妫€鏌ラ潤鎬佽妭鐐圭殑鍙樺寲銆傝繖澶уぇ鍑忓皯浜嗛渶瑕佽鍔ㄧ洃鎺х殑鍏冪礌鏁伴噺銆傜粍鍚堟墍鏈夎繖浜涜妭鐐瑰垱寤轰竴涓潡鏍戞垨涓€涓ā鏉匡紝璇ユā鏉挎牴鎹寚浠わ紙v-if銆乿-for锛夊垝鍒嗕负鑺傜偣鍧椼€傚湪BlockTree涓紝姣忎釜鑺傜偣閮芥湁锛氬畬鍏ㄩ潤鎬佺殑鑺傜偣缁撴瀯涓嶉渶瑕佺洃鍚殑闈欐€佸唴瀹瑰彲浠ュ瓨鍌ㄥ湪鏁扮粍涓殑鍔ㄦ€佽妭鐐硅繖娑堥櫎浜嗛€掑綊妫€鏌ユ瘡涓厓绱犵殑闇€瑕侊紝澶уぇ鎻愰珮浜嗚繍琛屾椂闂淬€係taticTreeHoisting浣跨敤闈欐€佹爲鎻愬崌锛岃繖鎰忓懗鐫€Vue3鐨勭紪璇戝櫒灏嗚兘澶熸娴嬪埌浠€涔堟槸闈欐€佺殑锛岀劧鍚庡皢鍏舵彁鍗囷紝浠庤€岄檷浣庢覆鏌撴垚鏈€傚畠灏嗚兘澶熻烦杩囦慨琛ユ暣妫垫爲銆傝繖澶уぇ鍑忓皯浜嗚櫄鎷烡OM鐨勫伐浣滃苟鑺傜渷浜嗗ぇ鍨嬮」鐩紑閿€锛屼富瑕佹槸鍨冨溇鏀堕泦銆傛敮鎸乀ypescript鐨勫彟涓€涓彉鍖栨槸Vue浠g爜搴撳皢浣跨敤Typescript閲嶅啓銆傚墠绔殑璇濓紝瑕佸濂絋S鎵嶈兘鏇村ソ鐨勪笂鎵媀ue3銆傛墍浠ue涔熶负鎴戞彁渚涗簡涓や釜閫夋嫨锛氬鏋滀綘鎯宠Typescript锛屽氨浣跨敤瀹冦€傚鏋滄病鏈夛紝灏辩敤Vue2鐨勬柟寮忋€俆ypescript鏍囧噯鍖栦簡JS鍙橀噺涓殑绫诲瀷淇℃伅銆備粠闀胯繙鏉ョ湅锛岃繖鏈夊姪浜庢垜浠淮鎶ら」鐩€傝秴杞婚噺绾ueJS鐩墠宸茬粡闈炲父灏忥紙鍘嬬缉鍚?0kb锛夈€傜劧鑰岋紝Vue鍥㈤槦闈复涓€涓棶棰橈細鏂板姛鑳藉鍔犱簡姣忎釜鐢ㄦ埛鐨勫寘澶у皬锛屾棤璁轰粬浠槸鍚︿娇鐢ㄥ畠銆備负浜嗚В鍐宠繖涓棶棰橈紝Vue3杩涜浜嗘洿褰诲簳鐨勬ā鍧楀寲銆傝繖鏍峰仛浼氬鍔犻渶瑕佸紑鍙戠殑瀵煎叆妯″潡鐨勬暟閲忥紝浣嗙‘淇濆皢鏈娇鐢ㄧ殑搴撴媺鍏ユ垜浠殑椤圭洰銆傜敱浜巘reeshaking锛孷ue3鐨勪及璁″ぇ灏忕害涓?0kb銆傚綋鐒讹紝闇€瑕佸鍏ュ緢澶氬簱銆傚噯澶囧ソ锛熷鏋滄偍鏄疺ue鐢ㄦ埛锛屽緢鏄庢樉Vue3涓殑鏇存柊灏嗕娇瀹冩洿鍔犲彲鐢ㄥ拰寮哄ぇ銆備粠娓叉煋浼樺寲鍒板府鍔╁紑鍙戣€呯紪鍐欐洿鍏峰彲璇绘€?鍙淮鎶ゆ€х殑浠g爜锛孷ue3鏀硅繘浜嗚澶歏ue2閬囧埌鐨勭棝鐐广€俈ue3宸茬粡姝e紡鍙戝竷锛屽噯澶囧ソ浜嗗悧锛屽揩鏉ュ涔犲惂锛佸師鏂囷細https://medium.com/swlh/what-...浠g爜閮ㄧ讲鍚庡彲鑳藉瓨鍦ㄧ殑bug鏃犳硶瀹炴椂鑾风煡銆備箣鍚庝负浜嗚В鍐宠繖浜汢UG锛屽緢澶氭椂闂撮兘鑺卞湪浜嗘棩蹇楄皟璇曚笂锛岄『渚挎帹鑽愮粰澶у涓€涓ソ鐢ㄧ殑BUG鐩戞帶宸ュ叿Fundebug銆備氦娴佹枃绔犳瘡鍛ㄦ洿鏂般€傚彲浠ュ井淇℃悳绱⑩€滃ぇ鍗冧笘鐣屸€濋槄璇诲嵆鏃舵洿鏂帮紙姣斿崥鏂囨棭涓€涓ょ瘒锛夈€傛湰鏂囧凡鏀跺綍鍒癎itHubhttps://github.com/qq449245884/xiaozhi銆傛垜鐨勬枃妗e彂琛ㄤ簡寰堝锛屾杩嶴tar鍜屽畬鍠勶紝鍙互鍙傝€冭€冭瘯涓績闈㈣瘯澶嶄範锛屽叧娉ㄥ叕浼楀彿锛屽悗鍙颁細鍥炲绂忓埄锛岀鍒╁彲浠ョ湅鍒帮紝浣犵煡閬撱€?/p>