fastapi/docs/zh-hant/docs/tutorial/body-fields.md

2.3 KiB
Raw Blame History

Body - 欄位

就像你可以在「路徑操作函式 (path operation function)」的參數中用 QueryPathBody 宣告額外的驗證與中繼資料一樣,你也可以在 Pydantic 模型中使用 Pydantic 的 Field 來宣告驗證與中繼資料。

匯入 Field

首先,你需要匯入它:

{* ../../docs_src/body_fields/tutorial001_an_py310.py hl[4] *}

/// warning

請注意,Field 是直接從 pydantic 匯入的,不像其他(如 QueryPathBody 等)是從 fastapi 匯入。

///

宣告模型屬性

接著你可以在模型屬性上使用 Field

{* ../../docs_src/body_fields/tutorial001_an_py310.py hl[11:14] *}

Field 的用法與 QueryPathBody 相同,擁有相同的參數等。

/// note | 技術細節

實際上,你接下來會看到的 QueryPath 等,會建立共同父類別 Param 的子類別物件,而 Param 本身是 Pydantic 的 FieldInfo 類別的子類別。

而 Pydantic 的 Field 也會回傳一個 FieldInfo 的實例。

Body 也會直接回傳 FieldInfo 子類別的物件。稍後你會看到還有其他類別是 Body 類別的子類別。

記得,當你從 fastapi 匯入 QueryPath 等時,它們其實是回傳特殊類別的函式。

///

/// tip

注意,每個帶有型別、預設值與 Field 的模型屬性,其結構和「路徑操作函式」的參數相同,只是把 PathQueryBody 換成了 Field

///

加入額外資訊

你可以在 FieldQueryBody 等中宣告額外資訊。這些資訊會被包含在產生的 JSON Schema 中。

你會在後續文件中學到更多關於加入額外資訊的內容,特別是在宣告範例時。

/// warning

傳入 Field 的額外鍵也會出現在你的應用程式所產生的 OpenAPI schema 中。 由於這些鍵不一定屬於 OpenAPI 規格的一部分,一些 OpenAPI 工具(例如 OpenAPI 驗證器)可能無法處理你產生的 schema。

///

回顧

你可以使用 Pydantic 的 Field 為模型屬性宣告額外的驗證與中繼資料。

你也可以使用額外的關鍵字引數來傳遞額外的 JSON Schema 中繼資料。