Vue中如何運(yùn)用TS語法
一、父子傳值的用法
父傳子:defineProps的TS寫法
// 父組件:和 vue2 一樣正常傳值
<template>
<div class="login-page">
<cp-nav-bar title="登錄" right-text="注冊(cè)"></cp-nav-bar>
</div>
</template>
// 子組件:接收
<script setup lang="ts">
import { defineProps } from 'vue'
const props = defineProps<{
title: string
rightText?: string // ?表示可傳可不傳
}>()
// js中使用
console.log(props.title)
</script>
<template>
<!-- 模板中直接使用變量名 -->
<van-nav-bar
fixed
left-arrow
:title="title"
:right-text="rightText"
></van-nav-bar>
</template>
補(bǔ)充:
如果需要給 props 設(shè)置默認(rèn)值,需要使用 withDefaults 函數(shù):
const props = withDefaults(defineProps<{
title?: string
rightText?: string
}>(),{
title: '首頁'
})
// 以上代碼通過語法糖解構(gòu),可以優(yōu)化成如下代碼:
const { title, title= "首頁" } = defineProps<{
title?: string
rightText?: string
}>();
子傳父:defineEmits的TS寫法
// 子傳
const emit = defineEmits<{
(e: 'changeMoney', money: number): void
(e: 'changeCar', car: string): void
}>()
// 父組件:和 vue2 一樣正常接收
// @changeMoney="方法名"
二、ref/reactive的TS用法
1.簡單數(shù)據(jù)類型可以不定義ts類型
ref() 會(huì)隱式的依據(jù)數(shù)據(jù)推導(dǎo)類型
// const money = ref<number>(10) const money = ref(10)
2.如果是復(fù)雜類型,建議用泛型
type Todo = {
id: number
name: string
done: boolean
}
const list = ref<Todo[]>([])
list.value = [
{ id: 1, name: '吃飯', done: false },
{ id: 2, name: '睡覺', done: true }
]
三、computed的TS用法
推薦泛型,一行搞定
const total = computed<string>(() => (count.value * 2).toFixed(2));
四、非空斷言
1.可選鏈
<script setup lang="ts">
import { onMounted, ref } from 'vue';
const input = ref< HTMLInputElement | null >(null)
onMounted(()=>{
// 如果獲取的元素不是input,就可能沒有value值
console.log(input.value?.value);
})
</script>
<template>
<div>App組件</div>
<input type="text" ref="input" value="abc">
</template>2.非空斷言
// 一定要確定不為空?。?! console.log(input.value!.value) input.value!.value = '123'
五、自定義TypeScript類型聲明文件
1.給JS文件提供類型
在導(dǎo)入 .js 文件時(shí),TS 會(huì)自動(dòng)加載與 .js 同名的 .d.ts 文件,以提供類型聲明。
具體步驟如下:
1.declare 關(guān)鍵字:用于類型聲明,為其他地方(比如,.js 文件)已存在的變量聲明類型,而不是創(chuàng)建一個(gè)新的變量。
2.對(duì)于 type interface 等這些明確就是 TS 類型的(只能在 TS 中使用的),可以省略 declare 關(guān)鍵字。
3.其他 JS 變量,應(yīng)該使用 declare 關(guān)鍵字,明確指定此處用于類型聲明。
// 參考示例:自定義組件的類型,必須是同名的.d.ts文件
import CpIcon from '@/components/CpIcon.vue'
declare module 'vue' {
interface GlobalComponents {
CpIcon: typeof CpIcon
}
}
2.共享類型
如果多個(gè) .ts 文件中都用到同一個(gè)類型,此時(shí)可以創(chuàng)建 .d.ts 文件提供該類型,實(shí)現(xiàn)類型共享。
1.創(chuàng)建 index.d.ts 類型聲明文件。
2.創(chuàng)建需要共享的類型,并使用 export 導(dǎo)出(TS 中的類型也可以使用 import/export 實(shí)現(xiàn)模塊化功能)。
3.在需要使用共享類型的 .ts 文件中,通過 import 導(dǎo)入即可(.d.ts 后綴導(dǎo)入時(shí),直接省略)。
到此這篇關(guān)于Vue中如何運(yùn)用TS語法的文章就介紹到這了,更多相關(guān)Vue運(yùn)用TS語法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解基于Vue cli開發(fā)修改外部組件Vant默認(rèn)樣式
這篇文章主要介紹了詳解基于Vue cli開發(fā)修改外部組件Vant默認(rèn)樣式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Vue中v-for的數(shù)據(jù)分組實(shí)例
下面小編就為大家分享一篇Vue中v-for的數(shù)據(jù)分組實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03
Vite打包性能優(yōu)化之開啟Gzip壓縮實(shí)踐過程
vue前端項(xiàng)目發(fā)布的時(shí)候,打包可實(shí)現(xiàn)gzip格式的壓縮,下面這篇文章主要給大家介紹了關(guān)于Vite打包性能優(yōu)化之開啟Gzip壓縮的相關(guān)資料,需要的朋友可以參考下2022-12-12
uniapp實(shí)現(xiàn)webview頁面關(guān)閉功能的代碼示例
uniapp用web-view打開一個(gè)網(wǎng)頁,網(wǎng)頁中點(diǎn)擊跳轉(zhuǎn)到下一層級(jí)的網(wǎng)頁,一層層深入,點(diǎn)擊返回鍵或者頁面上方返回按鈕只能一層層往回退,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)webview頁面關(guān)閉功能的相關(guān)資料,需要的朋友可以參考下2024-03-03
如何通過Vue自定義指令實(shí)現(xiàn)前端埋點(diǎn)詳析
埋點(diǎn)分析是網(wǎng)站分析的一種常用的數(shù)據(jù)采集方法,下面這篇文章主要給大家介紹了關(guān)于如何通過Vue自定義指令實(shí)現(xiàn)前端埋點(diǎn)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
Vue使用pages構(gòu)建多頁應(yīng)用的實(shí)現(xiàn)步驟
在大部分實(shí)際場景中,我們都可以構(gòu)建單頁應(yīng)用來進(jìn)行項(xiàng)目的開發(fā)和迭代,然而對(duì)于項(xiàng)目復(fù)雜度過高或者頁面模塊之間差異化較大的項(xiàng)目,我們可以選擇構(gòu)建多頁應(yīng)用來實(shí)現(xiàn),那么什么是多頁應(yīng)用,本文就給大家介紹了Vue使用pages構(gòu)建多頁應(yīng)用的實(shí)現(xiàn)步驟2024-12-12
Vue 2.5.2下axios + express 本地請(qǐng)求404的解決方法
下面小編就為大家分享一篇Vue 2.5.2下axios + express 本地請(qǐng)求404的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02
vue3新擬態(tài)組件庫開發(fā)流程之table組件源碼分析
這篇文章主要介紹了vue3新擬態(tài)組件庫開發(fā)流程——table組件源碼,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04
vue中el-select 和el-tree二次封裝實(shí)現(xiàn)
本文介紹了vue中el-select 和el-tree二次封裝實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-11-11

