亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中如何運(yùn)用TS語(yǔ)法

 更新時(shí)間:2023年02月28日 10:51:48   作者:Her...  
本文主要介紹了Vue中如何運(yùn)用TS語(yǔ)法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

一、父子傳值的用法

父?jìng)髯樱篸efineProps的TS寫(xiě)法

// 父組件:和 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: '首頁(yè)'
})
 
// 以上代碼通過(guò)語(yǔ)法糖解構(gòu),可以優(yōu)化成如下代碼:
const { title, title= "首頁(yè)" } = defineProps<{
  title?: string
  rightText?: string
}>();

子傳父:defineEmits的TS寫(xiě)法

// 子傳
const emit = defineEmits<{
  (e: 'changeMoney', money: number): void
  (e: 'changeCar', car: string): void
}>()
 
// 父組件:和 vue2 一樣正常接收
// @changeMoney="方法名"

二、ref/reactive的TS用法

1.簡(jiǎn)單數(shù)據(jù)類(lèi)型可以不定義ts類(lèi)型

ref() 會(huì)隱式的依據(jù)數(shù)據(jù)推導(dǎo)類(lèi)型

// const money = ref<number>(10)
const money = ref(10)

2.如果是復(fù)雜類(lèi)型,建議用泛型

type Todo = {
  id: number
  name: string
  done: boolean
}
const list = ref<Todo[]>([])
list.value = [
  { id: 1, name: '吃飯', done: false },
  { id: 2, name: '睡覺(jué)', 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,就可能沒(méi)有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類(lèi)型聲明文件

1.給JS文件提供類(lèi)型

在導(dǎo)入 .js 文件時(shí),TS 會(huì)自動(dòng)加載與 .js 同名的 .d.ts 文件,以提供類(lèi)型聲明。

具體步驟如下:

1.declare 關(guān)鍵字:用于類(lèi)型聲明,為其他地方(比如,.js 文件)已存在的變量聲明類(lèi)型,而不是創(chuàng)建一個(gè)新的變量。

2.對(duì)于 type interface 等這些明確就是 TS 類(lèi)型的(只能在 TS 中使用的),可以省略 declare 關(guān)鍵字。

3.其他 JS 變量,應(yīng)該使用 declare 關(guān)鍵字,明確指定此處用于類(lèi)型聲明。

// 參考示例:自定義組件的類(lèi)型,必須是同名的.d.ts文件
import CpIcon from '@/components/CpIcon.vue'
 
declare module 'vue' {
  interface GlobalComponents {
    CpIcon: typeof CpIcon
  }
}

2.共享類(lèi)型

如果多個(gè) .ts 文件中都用到同一個(gè)類(lèi)型,此時(shí)可以創(chuàng)建 .d.ts 文件提供該類(lèi)型,實(shí)現(xiàn)類(lèi)型共享。

1.創(chuàng)建 index.d.ts 類(lèi)型聲明文件。

2.創(chuàng)建需要共享的類(lèi)型,并使用 export 導(dǎo)出(TS 中的類(lèi)型也可以使用 import/export 實(shí)現(xiàn)模塊化功能)。

3.在需要使用共享類(lèi)型的 .ts 文件中,通過(guò) import 導(dǎo)入即可(.d.ts 后綴導(dǎo)入時(shí),直接省略)。

到此這篇關(guān)于Vue中如何運(yùn)用TS語(yǔ)法的文章就介紹到這了,更多相關(guān)Vue運(yùn)用TS語(yǔ)法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3中關(guān)于路由規(guī)則的props配置方式

    Vue3中關(guān)于路由規(guī)則的props配置方式

    這篇文章主要介紹了Vue3中關(guān)于路由規(guī)則的props配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue中watch監(jiān)聽(tīng)路由傳來(lái)的參數(shù)變化問(wèn)題

    vue中watch監(jiān)聽(tīng)路由傳來(lái)的參數(shù)變化問(wèn)題

    這篇文章主要介紹了vue中watch監(jiān)聽(tīng)路由傳來(lái)的參數(shù)變化,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • vue 中基于html5 drag drap的拖放效果案例分析

    vue 中基于html5 drag drap的拖放效果案例分析

    本文通過(guò)三個(gè)案例給大家介紹了vue 中基于html5 drag drap的拖放效果 ,需要的朋友可以參考下
    2018-11-11
  • vue如何實(shí)現(xiàn)Json格式數(shù)據(jù)展示

    vue如何實(shí)現(xiàn)Json格式數(shù)據(jù)展示

    這篇文章主要介紹了vue如何實(shí)現(xiàn)Json格式數(shù)據(jù)展示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue.js實(shí)戰(zhàn)之組件的進(jìn)階

    Vue.js實(shí)戰(zhàn)之組件的進(jìn)階

    組件(Component)是 Vue.js 最強(qiáng)大的功能之一,之前的文章都只是用到了基本的封裝功能,這次將介紹一些更強(qiáng)大的擴(kuò)展。這篇文章主要介紹了Vue.js實(shí)戰(zhàn)之組件進(jìn)階的相關(guān)資料,需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2017-04-04
  • 詳解Vue自定義指令及使用

    詳解Vue自定義指令及使用

    這篇文章主要介紹了Vue自定義指令及使用,對(duì)Vue感興趣的同學(xué),可以參考下
    2021-05-05
  • WEB前端性能優(yōu)化的7大手段詳解

    WEB前端性能優(yōu)化的7大手段詳解

    本文將詳細(xì)介紹前端性能優(yōu)化的7大手段,包括減少請(qǐng)求數(shù)量、減小資源大小、優(yōu)化網(wǎng)絡(luò)連接、優(yōu)化資源加載、減少重繪回流、使用性能更好的API和構(gòu)建優(yōu)化
    2020-02-02
  • Vue如何基于es6導(dǎo)入外部js文件

    Vue如何基于es6導(dǎo)入外部js文件

    這篇文章主要介紹了Vue如何基于es6導(dǎo)入外部js文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • 如何使用elementUI組件實(shí)現(xiàn)表格的分頁(yè)及搜索功能

    如何使用elementUI組件實(shí)現(xiàn)表格的分頁(yè)及搜索功能

    最近在使用element-ui的表格組件時(shí),遇到了搜索框功能的實(shí)現(xiàn)問(wèn)題,這篇文章主要給大家介紹了關(guān)于如何使用elementUI組件實(shí)現(xiàn)表格的分頁(yè)及搜索功能的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • vue-element-admin后臺(tái)生成動(dòng)態(tài)路由及菜單方法詳解

    vue-element-admin后臺(tái)生成動(dòng)態(tài)路由及菜單方法詳解

    vue-element-admin后臺(tái)管理系統(tǒng)模板框架 是vue結(jié)合element-ui一體的管理系統(tǒng)框架,下面這篇文章主要給大家介紹了關(guān)于vue-element-admin后臺(tái)生成動(dòng)態(tài)路由及菜單的相關(guān)資料,需要的朋友可以參考下
    2023-09-09

最新評(píng)論