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

使用Vue3时要避免的10个错误

时间:2023-03-31 22:12:04 vue.js

Vue3宸茬粡绋冲畾浜嗕竴娈垫椂闂淬€傝澶氫唬鐮佸簱鍦ㄧ敓浜т腑浣跨敤瀹冿紝鍏朵粬鎵€鏈変汉鏈€缁堥兘蹇呴』杩佺Щ鍒癡ue3銆傛垜鐜板湪鏈夋満浼氫娇鐢ㄥ畠骞惰褰曚簡鎴戠殑閿欒锛屾偍鍙兘甯屾湜閬垮厤杩欎簺閿欒銆備娇鐢≧eactive澹版槑鍘熷鍊兼暟鎹0鏄庢浘缁忛潪甯哥畝鍗曪紝浣嗙幇鍦ㄦ湁寰堝杈呭姪鍑芥暟鍙緵鎴戜滑浣跨敤銆傜洰鍓嶇殑瑙勫垯鏄細浣跨敤reactive澹版槑Object銆丄rray銆丮ap銆丼et锛屼娇鐢╮ef澹版槑String銆丯umber銆丅oolean浣跨敤reactive瀵逛簬鍘熷鍊间細杩斿洖涓€涓獁arning锛岃鍊间笉浼氬彉鎴恟eactivedata銆?*娌℃湁鎸夐鏈熷伐浣?/鐭涚浘鐨勬槸锛屽彟涓€绉嶆柟娉曟槸鍙兘鐨勩€備緥濡傦紝浣跨敤ref澹版槑涓€涓狝rray浼氬湪鍐呴儴璋冪敤reactive銆傝В鏋勫搷搴斿紡鏁版嵁鍋囪鎮ㄦ湁涓€涓叿鏈夎鏁板睘鎬х殑鍝嶅簲寮忓璞″拰涓€涓敤浜庡鍔犺鏁扮殑鎸夐挳銆?template>Counter:{{state.count}}澧炲姞涓婇潰鐨勯€昏緫闈炲父绠€鍗曞苟涓旀寜棰勬湡宸ヤ綔锛屼絾鏄偍鍙互浣跨敤javascript鐨勮В鏋勬潵鎵ц浠ヤ笅鎿嶄綔锛?*涓嶆寜棰勬湡宸ヤ綔*/浠g爜鐪嬭捣鏉ユ槸涓€鏍风殑锛屾牴鎹垜浠箣鍓嶇殑缁忛獙锛屽簲璇ュ彲浠ワ紝浣嗗疄闄呬笂锛孷ue鐨勫搷搴斿紡璺熻釜鏄€氳繃灞炴€ц闂€傝繖鎰忓懗鐫€鎴戜滑鏃犳硶鍒嗛厤鎴栬В鏋勫弽搴斿璞★紝鍥犱负涓庣涓€涓紩鐢ㄧ殑鍙嶅簲杩炴帴宸叉柇寮€銆傝繖鏄娇鐢ㄥ搷搴斿紡杈呭姪鍑芥暟鐨勯檺鍒朵箣涓€銆傚.value鎰熷埌鍥版儜鍚屾牱锛屽甫鏈塺ef鐨勫鎬ā寮忓彲鑳藉緢闅句範鎯€俁ef鎺ュ彈涓€涓€煎苟杩斿洖涓€涓弽搴斿璞°€傝鍊煎湪.value灞炴€т笅鐨勫璞″唴閮ㄥ彲鐢ㄣ€俢onstcount=ref(0)console.log(count)//{value:0}console.log(count.value)//0count.value++console.log(count.value)//1浣唕ef鍦╰emplate鍦ㄦ枃浠朵腑浣跨敤鏃惰В鍖咃紝涓嶉渶瑕?value銆?scriptsetup>import{ref}from'vue'constcount=ref(0)functionincrement(){count.value++}浣嗘槸瑕佸皬蹇冿紒灞曞紑浠呴€傜敤浜庨《绾у睘鎬с€備笅闈㈢殑浠g爜鐗囨鐢熸垚[objectObject]銆?/涓嶈杩欐牱鍋?scriptsetup>import{ref}from'vue'constobject={foo:ref(1)}姝g‘浣跨敤.value闇€瑕佹椂闂淬€傛垜瓒婃潵瓒婇绻佸湴浣跨敤瀹冿紝灏界鏈夋椂鎴戜細蹇樿濡備綍浣跨敤瀹冦€傚彂灏勪簨浠惰嚜Vue鏈€鍒濆彂甯冧互鏉ワ紝瀛愮粍浠跺凡缁忚兘澶熶娇鐢╡mit涓庣埗缁勪欢杩涜閫氫俊銆傛偍鍙渶瑕佹坊鍔犱竴涓嚜瀹氫箟浜嬩欢渚﹀惉鍣ㄦ潵渚﹀惉浜嬩欢銆?/瀛愮粍浠秚his.$emit('my-event')//鐖剁粍浠?my-component@my-event="doSomething"/>鐜板湪锛岄渶瑕佷娇鐢╠efineEmits澹版槑emit銆?scriptsetup>constemit=defineEmits(['my-event'])emit('my-event')瑕佽浣忕殑鍙︿竴浠朵簨鏄紝涓嶉渶瑕佸鍏efineEmits鍜宒efineProps銆備娇鐢ㄨ剼鏈缃椂锛屽畠浠細鑷姩鍙敤銆?scriptsetup>constprops=defineProps({foo:String})constemit=defineEmits(['change','delete'])//setupcode鏈€鍚庯紝鐢变簬鐜板湪蹇呴』澹版槑浜嬩欢锛屾墍浠ヤ笉浣跨敤.native淇グ绗︼紝瀹為檯涓婂凡缁忚绉婚櫎浜嗐€傚0鏄庨檮鍔犻€夐」OptionsAPI鏂规硶鏈夊嚑涓湪鑴氭湰璁剧疆涓笉鍙楁敮鎸佺殑灞炴€с€俷ameinheritAttrs鎻掍欢鎴栧簱鎵€闇€鐨勮嚜瀹氫箟閫夐」鐨勮В鍐虫柟妗堟槸鍦ㄥ悓涓€缁勪欢涓缃袱涓笉鍚岀殑鑴氭湰锛屽鑴氭湰setupRFC鎵€瀹氫箟銆?script>exportdefault{name:'CustomName',inheritAttrs:false,customOptions:{}}浣跨敤鍝嶅簲寮忚浆鎹eactivityTransform鏄疺ue3鐨勪竴涓疄楠孉鏃ㄥ湪绠€鍖栫粍浠跺0鏄庢柟寮忕殑闈╁懡鎬т絾鏈変簤璁殑鍔熻兘銆傝繖涓兂娉曟槸浣跨敤缂栬瘧鏃惰浆鎹㈡潵鑷姩瑙e寘ref骞朵娇.value杩囨椂銆備絾鐜板湪瀹冨凡琚純鐢紝骞跺皢鍦╒ue3.3涓垹闄ゃ€傚畠浠嶇劧鍙互浣滀负涓€涓寘浣跨敤锛屼絾鐢变簬瀹冧笉鏄疺ue鏍稿績鐨勪竴閮ㄥ垎锛屾墍浠ユ渶濂戒笉瑕佸湪涓婇潰鎶曞叆鏃堕棿銆傚畾涔夊紓姝ョ粍浠朵互鍓嶏紝寮傛缁勪欢鏄€氳繃灏嗗叾灏佽鍦ㄥ嚱鏁颁腑鏉ュ0鏄庣殑銆俢onstasyncModal=()=>import('./Modal.vue')浠嶸ue3寮€濮嬶紝闇€瑕佷娇鐢╠efineAsyncComponent杈呭姪鍑芥暟鏄惧紡瀹氫箟寮傛缁勪欢銆俰mport{defineAsyncComponent}from'vue'constasyncModal=defineAsyncComponent(()=>import('./Modal.vue'))鍦ㄦā鏉夸腑浣跨敤鍐椾綑鍖呰鍏冪礌鍦╒ue2涓紝缁勪欢妯℃澘闇€瑕佸崟涓牴鍏冪礌锛岃繖鏈夋椂浼氬紩鍏ヤ笉蹇呰鐨勫寘瑁呭厓绱犮€?!--Layout.vue-->杩欎笉鍐嶆槸蹇呴渶鐨勶紝鍥犱负鐜板湪鏀寔澶氫釜鏍瑰厓绱犮€傪煡?!--Layout.vue-->浣跨敤閿欒鐨勭敓鍛藉懆鏈熸墍鏈夌粍浠剁敓鍛藉懆鏈熶簨浠堕兘宸查噸鍛藉悕锛屾坊鍔爋n鍓嶇紑鎴栧畬鍏ㄦ洿鏀瑰悕绉般€傛偍鍙互鍦ㄤ笅琛ㄤ腑鏌ョ湅鎵€鏈夋洿鏀广€備笉瑕佺湅鏂囨。鏈€鍚庯紝瀹樻柟鏂囨。宸茬粡杩囦慨璁互鍙嶆槧鏂扮殑API锛屽苟鍖呭惈璁稿鏈変环鍊肩殑娉ㄩ噴銆佹寚鍗楀拰鏈€浣冲疄璺点€傚嵆浣挎偍鏄竴浣嶇粡楠屼赴瀵岀殑Vue2宸ョ▼甯堬紝鎮ㄤ篃涓€瀹氫細閫氳繃闃呰鏂囨。鏉ュ涔犳柊鐨勪笢瑗裤€傛€荤粨姣忎釜妗嗘灦閮芥湁涓€涓涔犳洸绾匡紝Vue3鐨勫涔犳洸绾挎棤鐤戞瘮Vue2鏇撮櫋宄€傛垜浠嶇劧涓嶇浉淇′袱涓増鏈箣闂寸殑杩佺Щ宸ヤ綔鏄悎鐞嗙殑锛屼絾鏄粍鍚圓PI鏇村姞绠€娲侊紝涓€鏃︽帉鎻′簡瀹冨氨浼氭劅瑙夎嚜鐒躲€傛渶鍚庯紝璇疯浣忥細鐘敊鎬绘瘮浠€涔堥兘涓嶅仛瑕佸ソ銆傜姱閿欐€绘瘮浠€涔堥兘涓嶅仛瑕佸ソ寰楀銆傝繖灏辨槸鏈枃鐨勫叏閮ㄥ唴瀹广€傚鏋滃浣犳湁甯姪锛屾杩庣偣璧炴敹钘忚浆鍙憕