成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

七個(gè)讓我們成為更好 Vue 開發(fā)者的技巧

開發(fā) 前端
在這篇文章中,我將與你分享7個(gè)關(guān)于Vue3的技巧,希望對(duì)你有幫助。

我使用 Vue 已經(jīng)很多年了,特別是去年一直在使用 Vue3,因此,學(xué)到了很多東西。

1、腳本設(shè)置

如果以前使用過組合 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í)際效果:https://codesandbox.io/s/lingering-http-ryf2bj?file=/src/components/HelloWorld.vue

3、反應(yīng)式 CSS

在新版本的 Vue 中,一件非常棒的事情是,可以將 CSS 直接綁定到我們的變量中。我發(fā)現(xiàn)這對(duì)于我在去年構(gòu)建的一些應(yīng)用程序非常有用。

........
const color = ref('#f000');<style>
.text {
color: v-bind(color);
}
</style>

4、全局組件

時(shí)不時(shí)地,我們希望擁有全局可用的組件,而不是每次需要它們時(shí)都必須導(dǎo)入它們。

我們可以通過轉(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)該能夠通過在要使用全局組件的組件中的模板中編寫 <MyGlobalSection /> 來全局使用該組件

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)它使用起來更靈活,而且我開始使用 composeables,它被認(rèn)為是 mixins 的替代品。非常強(qiáng)大且非常酷的補(bǔ)充。

6、使用 v-once 或 v-memo 提高性能

如果你關(guān)心快速渲染,可能希望使用 Vue 的內(nèi)置指令之一,例如 v-once 或 v-memo 來提高應(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é)果以加快未來渲染的速度。  

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 來延遲加載組件。  

這意味著該組件僅在需要時(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 */,
});
責(zé)任編輯:龐桂玉 來源: WEB前端開發(fā)社區(qū)
相關(guān)推薦

2020-03-31 09:47:04

Vue開發(fā)代碼

2016-03-04 10:18:24

xcode技巧開發(fā)

2016-03-04 10:25:50

Xcode技巧開發(fā)

2023-03-27 23:57:25

JavaScrip開發(fā)技巧

2017-02-10 12:02:39

Node開發(fā)者

2022-12-07 15:01:47

2023-10-17 18:03:30

Code更改函數(shù)

2023-09-08 10:23:13

JavaScriptNPM模塊

2025-01-26 10:49:52

2021-12-08 10:31:46

ITIT領(lǐng)導(dǎo)IT管理

2023-11-17 14:18:48

開發(fā)編程

2017-04-13 10:58:32

Python開發(fā)者

2023-11-27 15:49:55

軟件開發(fā)系統(tǒng)設(shè)計(jì)

2010-12-03 11:17:12

2016-12-13 10:06:25

編寫Java單元測(cè)試技巧

2022-06-08 08:55:15

JavaScript代碼前端

2023-04-19 15:29:53

通信技巧Vue 3開發(fā)

2024-02-28 07:48:05

Rust項(xiàng)目框架

2024-04-26 13:36:01

2024-12-31 00:12:39

命令Docker網(wǎng)絡(luò)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 毛片入口 | 亚洲精品在线视频 | 欧美日韩毛片 | 免费看啪啪网站 | 男人的天堂在线视频 | 天天天天操 | 国产一区二区三区四区五区加勒比 | 日韩免费福利视频 | 国产毛片久久久久久久久春天 | 99视频在线免费观看 | 国产一区二区免费 | 国产激情视频在线观看 | 日韩一级 | 日韩在线观看网站 | 午夜免费视频 | 亚洲国产aⅴ成人精品无吗 亚洲精品久久久一区二区三区 | 亚洲精品专区 | 国产黄色大片 | 人人看人人爽 | av免费网站在线 | 日韩欧美国产一区二区 | 男女羞羞视频网站 | 色男人的天堂 | 日韩国产高清在线观看 | 国产特一级黄色片 | 日韩一二区| 精品久久久网站 | 你懂的在线视频播放 | 中文字幕日韩欧美一区二区三区 | 神马久久久久久久久久 | 中文字幕av一区二区三区 | 精品久久一区 | 天天爽网站 | 国产丝袜一区二区三区免费视频 | 免费成人高清在线视频 | 国产一区91精品张津瑜 | 久久久久久亚洲 | www.国产视频 | 3级毛片 | 亚洲 中文 欧美 日韩 在线观看 | 毛片在线视频 |