diff --git a/src/guide/typescript/options-api.md b/src/guide/typescript/options-api.md index 94ff7510..70fe8553 100644 --- a/src/guide/typescript/options-api.md +++ b/src/guide/typescript/options-api.md @@ -1,20 +1,20 @@ -# TypeScript 与选项式 API {#typescript-with-options-api} +# TypeScript 與選項式 API {#typescript-with-options-api} -> 这一章假设你已经阅读了[搭配 TypeScript 使用 Vue](./overview) 的概览。 +> 這一章假設你已經閱讀了[搭配 TypeScript 使用 Vue](./overview) 的概覽。 :::tip -虽然 Vue 的确支持在选项式 API 中使用 TypeScript,但在使用 TypeScript 的前提下更推荐使用组合式 API,因为它提供了更简单、高效和可靠的类型推导。 +雖然 Vue 的確支持在選項式 API 中使用 TypeScript,但在使用 TypeScript 的前提下更推薦使用組合式 API,因為它提供了更簡單、高效和可靠的類型推導。 ::: -## 为组件的 props 标注类型 {#typing-component-props} +## 為組件的 props 標註類型 {#typing-component-props} -选项式 API 中对 props 的类型推导需要用 `defineComponent()` 来包装组件。有了它,Vue 才可以通过 `props` 以及一些额外的选项,比如 `required: true` 和 `default` 来推导出 props 的类型: +選項式 API 中對 props 的類型推導需要用 `defineComponent()` 來包裝組件。有了它,Vue 才可以通過 `props` 以及一些額外的選項,例如 `required: true` 和 `default` 來推導出 props 的類型: ```ts import { defineComponent } from 'vue' export default defineComponent({ - // 启用了类型推导 + // 啟用了類型推導 props: { name: String, id: [Number, String], @@ -22,17 +22,17 @@ export default defineComponent({ metadata: null }, mounted() { - this.name // 类型:string | undefined - this.id // 类型:number | string | undefined - this.msg // 类型:string - this.metadata // 类型:any + this.name // 類型:string | undefined + this.id // 類型:number | string | undefined + this.msg // 類型:string + this.metadata // 類型:any } }) ``` -然而,这种运行时 `props` 选项仅支持使用构造函数来作为一个 prop 的类型——没有办法指定多层级对象或函数签名之类的复杂类型。 +然而,這種運行時 `props` 選項僅支持使用構造函數來作為一個 prop 的類型——沒有辦法指定多層級對象或函數簽名之類的複雜類型。 -我们可以使用 `PropType` 这个工具类型来标记更复杂的 props 类型: +我們可以使用 `PropType` 這個工具類型來標記更復雜的 props 類型: ```ts import { defineComponent } from 'vue' @@ -47,11 +47,11 @@ interface Book { export default defineComponent({ props: { book: { - // 提供相对 `Object` 更确定的类型 + // 提供相對 `Object` 更確定的類型 type: Object as PropType, required: true }, - // 也可以标记函数 + // 也可以標記函數 callback: Function as PropType<(id: number) => void> }, mounted() { @@ -65,9 +65,9 @@ export default defineComponent({ }) ``` -### 注意事项 {#caveats} +### 注意事項 {#caveats} -如果你的 TypeScript 版本低于 `4.7`,在使用函数作为 prop 的 `validator` 和 `default` 选项值时需要格外小心——确保使用箭头函数: +如果你的 TypeScript 版本低於 `4.7`,在使用函數作為 prop 的 `validator` 和 `default` 選項值時需要格外小心——確保使用箭頭函數: ```ts import { defineComponent } from 'vue' @@ -82,7 +82,7 @@ export default defineComponent({ props: { bookA: { type: Object as PropType, - // 如果你的 TypeScript 版本低于 4.7,确保使用箭头函数 + // 如果你的 TypeScript 版本低於 4.7,確保使用箭頭函數 default: () => ({ title: 'Arrow Function Expression' }), @@ -92,11 +92,11 @@ export default defineComponent({ }) ``` -这会防止 TypeScript 将 `this` 根据函数内的环境作出不符合我们期望的类型推导。这是之前版本的一个[设计限制](https://github.com/microsoft/TypeScript/issues/38845),不过现在已经在 [TypeScript 4.7](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-4-7.html#improved-function-inference-in-objects-and-methods) 中解决了。 +這會防止 TypeScript 將 `this` 根據函數內的環境作出不符合我們期望的類型推導。這是之前版本的一個[設計限制](https://github.com/microsoft/TypeScript/issues/38845),不過現在已經在 [TypeScript 4.7](https://www.typescriptlang.org/docs/handbook/release-notes/typescript-4-7.html#improved-function-inference-in-objects-and-methods) 中解決了。 -## 为组件的 emits 标注类型 {#typing-component-emits} +## 為組件的 emits 標註類型 {#typing-component-emits} -我们可以给 `emits` 选项提供一个对象来声明组件所触发的事件,以及这些事件所期望的参数类型。试图触发未声明的事件会抛出一个类型错误: +我們可以給 `emits` 選項提供一個對象來聲明組件所觸發的事件,以及這些事件所期望的參數類型。試圖觸發未聲明的事件會拋出一個類型錯誤: ```ts import { defineComponent } from 'vue' @@ -104,25 +104,25 @@ import { defineComponent } from 'vue' export default defineComponent({ emits: { addBook(payload: { bookName: string }) { - // 执行运行时校验 + // 執行運行時校驗 return payload.bookName.length > 0 } }, methods: { onSubmit() { this.$emit('addBook', { - bookName: 123 // 类型错误 + bookName: 123 // 類型錯誤 }) - this.$emit('non-declared-event') // 类型错误 + this.$emit('non-declared-event') // 類型錯誤 } } }) ``` -## 为计算属性标记类型 {#typing-computed-properties} +## 為計算屬性標記類型 {#typing-computed-properties} -计算属性会自动根据其返回值来推导其类型: +計算屬性會自動根據其返回值來推導其類型: ```ts import { defineComponent } from 'vue' @@ -139,12 +139,12 @@ export default defineComponent({ } }, mounted() { - this.greeting // 类型:string + this.greeting // 類型:string } }) ``` -在某些场景中,你可能想要显式地标记出计算属性的类型以确保其实现是正确的: +在某些場景中,你可能想要顯式地標記出計算屬性的類型以確保其實現是正確的: ```ts import { defineComponent } from 'vue' @@ -156,12 +156,12 @@ export default defineComponent({ } }, computed: { - // 显式标注返回类型 + // 顯式標註返回類型 greeting(): string { return this.message + '!' }, - // 标注一个可写的计算属性 + // 標註一個可寫的計算屬性 greetingUppercased: { get(): string { return this.greeting.toUpperCase() @@ -174,11 +174,11 @@ export default defineComponent({ }) ``` -在某些 TypeScript 因循环引用而无法推导类型的情况下,可能必须进行显式的类型标注。 +在某些 TypeScript 因循環引用而無法推導類型的情況下,可能必須進行顯式的類型標註。 -## 为事件处理函数标注类型 {#typing-event-handlers} +## 為事件處理函數標註類型 {#typing-event-handlers} -在处理原生 DOM 事件时,应该为我们传递给事件处理函数的参数正确地标注类型。让我们看一下这个例子: +在處理原生 DOM 事件時,應該為我們傳遞給事件處理函數的參數正確地標註類型。讓我們看一下這個例子: ```vue