中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue中怎么運用TS語法

發布時間:2023-02-28 14:19:09 來源:億速云 閱讀:110 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Vue中怎么運用TS語法”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Vue中怎么運用TS語法”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

一、父子傳值的用法

父傳子:defineProps的TS寫法

// 父組件:和 vue2 一樣正常傳值
<template>
  <div class="login-page">
    <cp-nav-bar title="登錄" right-text="注冊"></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>

補充:

如果需要給 props 設置默認值,需要使用 withDefaults 函數:

const props = withDefaults(defineProps<{
  title?: string
  rightText?: string
}>(),{
  title: '首頁'
})
 
// 以上代碼通過語法糖解構,可以優化成如下代碼:
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.簡單數據類型可以不定義ts類型

ref() 會隱式的依據數據推導類型

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

2.如果是復雜類型,建議用泛型

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文件提供類型

在導入 .js 文件時,TS 會自動加載與 .js 同名的 .d.ts 文件,以提供類型聲明。

具體步驟如下:

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

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

3.其他 JS 變量,應該使用 declare 關鍵字,明確指定此處用于類型聲明。

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

2.共享類型

如果多個 .ts 文件中都用到同一個類型,此時可以創建 .d.ts 文件提供該類型,實現類型共享。

1.創建 index.d.ts 類型聲明文件。

2.創建需要共享的類型,并使用 export 導出(TS 中的類型也可以使用 import/export 實現模塊化功能)。

3.在需要使用共享類型的 .ts 文件中,通過 import 導入即可(.d.ts 后綴導入時,直接省略)。

讀到這里,這篇“Vue中怎么運用TS語法”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

时尚| 长子县| 林周县| 仙居县| 密山市| 寻乌县| 萝北县| 格尔木市| 陵水| 洛隆县| 衡阳市| 无棣县| 大城县| 门头沟区| 浏阳市| 浪卡子县| 化德县| 五华县| 东乡族自治县| 永宁县| 巴彦淖尔市| 丁青县| 长白| 朝阳区| 饶阳县| 西乌珠穆沁旗| 阳东县| 谢通门县| 彭山县| 陆良县| 青川县| 九江县| 图片| 华宁县| 新郑市| 临邑县| 苏尼特右旗| 霍林郭勒市| 河东区| 门源| 天全县|