分享7個(gè)成為更好的Vue開發(fā)者的技巧
1、腳本設(shè)置
如果以前使用過(guò)組合 API,我們需要始終執(zhí)行 defineComponent 和 setup() {}:
<script lang="ts"> import {defineComponent} from 'vue'; export default defineComponent({ name: 'Test', setup() { //Add business logic } }) </script>
對(duì)每個(gè)組件執(zhí)行此操作可能會(huì)相當(dāng)麻煩,實(shí)際上,可以避免對(duì)組件進(jìn)行引導(dǎo)??梢允褂?<script setup> ,它是如上所示執(zhí)行相同操作的簡(jiǎn)寫。它基本上只是頂部的語(yǔ)法糖,因此,不必每次都進(jìn)行手動(dòng)引導(dǎo):使用 <script setup>,您的組件將被簡(jiǎn)化為:
<script lang="ts" setup> //Add business logic </script>
2、如何覆蓋反應(yīng)對(duì)象
默認(rèn)情況下,當(dāng)定義一個(gè)響應(yīng)式對(duì)象時(shí),您不能覆蓋整個(gè)對(duì)象,如果這樣做,您將失去響應(yīng)性。
<script lang="ts"> import { defineComponent, reactive, onMounted } from "vue"; export default defineComponent({ name: "HelloWorld", setup() { let myReactiveObject = reactive({ name: "Nicky", age: "37", country: "DK", }); let newObject = { name: "Nicky Christensen", age: "36", country: "DA-DK", }; onMounted(() => { setTimeout(() => { //myReactiveObject = newObject //Wont work Object.assign(myReactiveObject, newObject) //Will work }, 2000) }) return { myReactiveObject, }; }, }); </script>
查看此 Codesandbox 以了解其實(shí)際效果
3、反應(yīng)式 CSS
在新版本的 Vue 中,一件非常棒的事情是,可以將 CSS 直接綁定到我們的變量中。我發(fā)現(xiàn)這對(duì)于我在去年構(gòu)建的一些應(yīng)用程序非常有用。
4、全局組件
時(shí)不時(shí)地,我們希望擁有全局可用的組件,而不是每次需要它們時(shí)都必須導(dǎo)入它們。
我們可以通過(guò)轉(zhuǎn)到 main.ts 并執(zhí)行以下操作輕松完成此操作:
import App from "./App.vue"; import MyGlobalSection from '@/components/MyGlobalSection.vue'; const app = createApp(App); // Make our <MyGlobalSection /> component globally available. app.component(MyGlobalSection.name, MyGlobalSection); app.mount("#app");
現(xiàn)在,我們應(yīng)該能夠通過(guò)在要使用全局組件的組件中的模板中編寫 <MyGlobalSection /> 來(lái)全局使用該組件
5、組合 API 優(yōu)于選項(xiàng) API
使用 Vue 3,我們獲得了 Composition API。這是對(duì) Vue 的一個(gè)真正偉大的補(bǔ)充,我認(rèn)為總是選擇使用 Composition API 而不是 Options API。
我喜歡 Composition API 的一點(diǎn)是,我發(fā)現(xiàn)它使用起來(lái)更靈活,而且我開始使用 composeables,它被認(rèn)為是 mixins 的替代品。非常強(qiáng)大且非??岬难a(bǔ)充。
6、使用 v-once 或 v-memo 提高性能
如果你關(guān)心快速渲染,可能希望使用 Vue 的內(nèi)置指令之一,例如 v-once 或 v-memo 來(lái)提高應(yīng)用程序的渲染性能。
v-once,可以在多個(gè)元素中應(yīng)用 v-once,例如常規(guī)元素、循環(huán)中或組件。
<template> <!-- single --> <p v-once>{{ someProperty }}</p> <!-- with children --> <div v-once> <p>{{ someProperty}}</p> </div> <!-- components --> <my-component v-once /> <!-- v-for directives --> <li v-for="”item" in items” v-once>{{item}}</li> </template>
v-memo;簡(jiǎn)而言之,v-memo 用于記憶模板的子樹,這意味著它存儲(chǔ)先前渲染的結(jié)果以加快未來(lái)渲染的速度。
v-memo 指令可用于元素和組件,并且可以。v-memo 接受一個(gè)數(shù)組,并且只有當(dāng)數(shù)組中的一個(gè)值發(fā)生變化時(shí)才會(huì)重新渲染。
<div v-memo="[valueA, valueB]"> ... </div>
如果 valueA 或 valueB 發(fā)生變化,它將更新。但請(qǐng)注意,v-memo 在 v-for 循環(huán)中不起作用。
7、組件的異步加載
為了讓你的應(yīng)用程序更高效并最小化你的主包,延遲加載你的組件是個(gè)好主意。在 Vue3 中,我們可以使用 defineAsyncComponent 來(lái)延遲加載組件。
這意味著該組件僅在需要時(shí)才加載。使用這種技術(shù),您可以顯著改善應(yīng)用程序的負(fù)載。
定義異步組件的最簡(jiǎn)單方法可以像這樣完成:
import { defineAsyncComponent } from "vue"; // Lazy Load const myComponent = defineAsyncComponent(() => import("./components/myComponent.vue") );
但是,如果您需要它,您可以做更多的事情,將對(duì)象傳遞給 defineAsyncComponent:
const myComponent = defineAsyncComponent({ loader: () => import("./myComponent.vue"), loadingComponent: myLoadingComponent /* shows while loading */, errorComponent: myErrorComponent /* shows if there's an error */, delay: 1000 /* delay in ms before showing loading component */, timeout: 3000 /* timeout after this many ms */, });
到此這篇關(guān)于分享7個(gè)成為更好的Vue開發(fā)者的技巧的文章就介紹到這了,更多相關(guān)Vue技巧內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Element Plus實(shí)現(xiàn)Affix 固釘
本文主要介紹了Element Plus實(shí)現(xiàn)Affix 固釘,Affix組件用于將頁(yè)面元素固定在特定可視區(qū)域,文中通過(guò)示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下2021-07-07詳解如何優(yōu)雅的進(jìn)行Vue的狀態(tài)管理
隨著項(xiàng)目的發(fā)展和復(fù)雜性的增加,對(duì) Vuex 進(jìn)行更深入的了解和使用就變得非常重要,本篇文章將帶您探索 Vuex 的進(jìn)階使用,包括模塊化、命名空間、getter 的高級(jí)用法等,需要的朋友可以參考下2023-09-09vue中實(shí)現(xiàn)Monaco Editor自定義提示功能
最近小編接到一個(gè)項(xiàng)目,需要在瀏覽器的ide中支持自定義提示功能,接下來(lái)通過(guò)本文給大家介紹在vue中實(shí)現(xiàn)Monaco Editor自定義提示功能,需要的朋友可以參考下2019-07-07Vue無(wú)法讀取HTMLCollection列表的length問(wèn)題解決
這篇文章主要介紹了Vue無(wú)法讀取HTMLCollection列表的length問(wèn)題解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Vue2路由動(dòng)畫效果的實(shí)現(xiàn)代碼
本篇文章主要介紹了Vue2路由動(dòng)畫效果的實(shí)現(xiàn)代碼,可以根據(jù)不同的路徑去改變動(dòng)畫的效果,有興趣的可以了解一下2017-07-07