vue3中使用props和emits并指定其類型與默認(rèn)值
前言
本文主要描述 vue3 中 defineProps 與 defineEmits 分別在 JS 環(huán)境和 TS 環(huán)境中的使用方法。
defineProps 的使用
defineProps在使用的時候無需引入,默認(rèn)是全局方法。
- 在 js 開發(fā)的 vue3 項目中使用
const props = defineProps({
attr1: {
type: String, // S 必須大寫
default: "",
},
attr2: Boolean,
attr3: {
type: Number,
required: true,
},
});
js 環(huán)境中使用與 vue2 的使用方法類似,只是選項式 API 換成了組合式 API。定義 props 類型與默認(rèn)值都與 vue2 類型,vue3 中使用的是definePropsAPI,在此不多介紹。
- 在 ts 開發(fā)的 vue3 項目中使用
interface DeatilInf {
aaa: string;
bbb: number;
}
const props = withDefaults(
// 參數(shù)一:定義props類型:? 代表非必傳字段, :號后面緊跟的是數(shù)據(jù)類型或自定義接口, | 或多種類型
defineProps<{
name: string;
age?: number;
detail?: DeatilInf | any;
}>(),
// 參數(shù)二:指定非必傳字段的默認(rèn)值
{
age: 18,
detail: {},
}
);
使用 typeScript 開發(fā) vue3 項目定義 props 主要使用的 API 有兩個: defineProps 定義接收的 props 、withDefaults 定義接收的類型。
當(dāng)然,你也可以使用上述 js 環(huán)境使用的方法定義 props,但這樣做就失去了使用 TS 的意義了。
defineEmits 的使用
與 vue2 不同:vue3 在觸發(fā)事件之前需要定義事件。同樣在 vue3 中 defineEmits 也是全局 API
- js 中使用
const emits = defineEmits(["change", "input"]);
emits("chage", "data");
emits("input", { data: 123 });
- TS 中使用
enum EventName {
CHANGE = "change",
INPUT = "input",
}
const emits = defineEmits<{
(event: EventName.CHANGE, data: string[]): void;
(event: EventName.INPUT, data: string): void;
}>();
emits(EventName.CHANGE, ["data"]);
emits(EventName.INPUT, "123");
上面的代碼中使用了枚舉 enum 避免"魔法字符串"的出現(xiàn)。值得一提,ts 中也可以使用 js 的方式使用,那么就沒有發(fā)揮出‘T’的作用。
尤其在大型項目里面觸發(fā)數(shù)據(jù)的類型可能會出現(xiàn)意想不到的 bug,然后定位 bug 可能得花上好幾個小時。也可能會出現(xiàn)觸發(fā)事件的事件名字符串寫錯(俗稱魔法字符串)導(dǎo)致達(dá)不到預(yù)期效果。
總結(jié)
經(jīng)過上述代碼示例,可能覺得 ts 的寫法似乎更加麻煩了,不如 js 來的快。但是,我個人認(rèn)為使用 ts 開發(fā)不僅僅是提示友好,而且能有效避開很多的坑。可謂:"未雨綢繆"勝過“亡羊補(bǔ)牢”的好。
到此這篇關(guān)于vue3中使用props和emits并指定其類型與默認(rèn)值的文章就介紹到這了,更多相關(guān)vue3使用props和emits內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解Vue如何實現(xiàn)顏色選擇與調(diào)色板功能
顏色選擇和調(diào)色板是Web開發(fā)中常用的功能,Vue作為一個流行的JavaScript框架,可以方便地實現(xiàn)顏色選擇和調(diào)色板功能,本文講講如何在Vue中進(jìn)行顏色選擇和調(diào)色板吧2023-06-06
electron中使用本地數(shù)據(jù)庫的方法詳解
眾所周知,electron是可以開發(fā)桌面端的框架,那我們有一些數(shù)據(jù)不想讓別人看到,只能在自己的電腦上展示時怎么辦呢,這個時候就可以用到本地數(shù)據(jù)庫,本文將以sqlite3為例介紹一下electron如何使用本地數(shù)據(jù)庫2023-10-10
Vue項目中v-model和sync的區(qū)別及使用場景分析
在Vue項目中,v-model和.sync是實現(xiàn)父子組件雙向綁定的兩種方式,v-model主要用于表單元素和子組件的雙向綁定,通過modelValue和update:modelValue實現(xiàn),.sync修飾符則用于同步prop值,適合在子組件內(nèi)更新父組件prop值的場景,通過update:propName事件實現(xiàn)2024-11-11

