mirror of https://github.com/vapor/docs.git
Update Japanese translation for basics/content.ja.md
- Remove extra blank line to match English version - Fix spacing after 'in' in code examples - Fix full-width spaces around 'Content' - Correct 'Contents' typo to 'Content' - Fix 'coder' to 'コーダー' - Remove full-width space after 'await'
This commit is contained in:
parent
ab8e21853a
commit
a0c60f5a80
|
|
@ -28,7 +28,6 @@ struct Greeting: Content {
|
||||||
|
|
||||||
型を `Content` に準拠させると、コンテンツ API を扱うための追加ユーティリティが得られると同時に、`Codable` にも自動的に準拠するようになります。
|
型を `Content` に準拠させると、コンテンツ API を扱うための追加ユーティリティが得られると同時に、`Codable` にも自動的に準拠するようになります。
|
||||||
|
|
||||||
|
|
||||||
コンテンツの構造ができたら、`req.content` を使ってリクエストからデコードできます。
|
コンテンツの構造ができたら、`req.content` を使ってリクエストからデコードできます。
|
||||||
|
|
||||||
```swift
|
```swift
|
||||||
|
|
@ -136,18 +135,18 @@ let name: String? = req.query["name"]
|
||||||
Vapor は、`Content` タイプに対して `beforeEncode` および `afterDecode` を自動的に呼び出します。デフォルトの実装は何もしませんが、これらのメソッドを使用してカスタムロジックを実行することができます。
|
Vapor は、`Content` タイプに対して `beforeEncode` および `afterDecode` を自動的に呼び出します。デフォルトの実装は何もしませんが、これらのメソッドを使用してカスタムロジックを実行することができます。
|
||||||
|
|
||||||
```swift
|
```swift
|
||||||
// この Content がデコードされた後に実行されます。`mutating` は構造体のみに必要で、クラスには必要ありません。
|
// この Content がデコードされた後に実行されます。`mutating` は構造体のみに必要で、クラスには必要ありません。
|
||||||
mutating func afterDecode() throws {
|
mutating func afterDecode() throws {
|
||||||
// 名前は渡されないことがありますが、渡される場合は空文字列であってはなりません。
|
// 名前は *必ず* 渡される必要があり、空文字列であってはなりません。
|
||||||
self.name = self.name?.trimmingCharacters(in: .whitespacesAndNewlines)
|
self.name = self.name?.trimmingCharacters(in: .whitespacesAndNewlines)
|
||||||
if let name = self.name, name.isEmpty {
|
if let name = self.name, name.isEmpty {
|
||||||
throw Abort(.badRequest, reason: "Name must not be empty.")
|
throw Abort(.badRequest, reason: "Name must not be empty.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// この Contents がエンコードされる前に実行されます。`mutating` は構造体のみに必要で、クラスには必要ありません。
|
// この Content がエンコードされる前に実行されます。`mutating` は構造体のみに必要で、クラスには必要ありません。
|
||||||
mutating func beforeEncode() throws {
|
mutating func beforeEncode() throws {
|
||||||
// 名前は渡されないことがありますが、渡される場合は空文字列であってはなりません。
|
// 名前は *必ず* 渡される必要があり、空文字列であってはなりません。
|
||||||
guard
|
guard
|
||||||
let name = self.name?.trimmingCharacters(in: .whitespacesAndNewlines),
|
let name = self.name?.trimmingCharacters(in: .whitespacesAndNewlines),
|
||||||
!name.isEmpty
|
!name.isEmpty
|
||||||
|
|
@ -214,7 +213,7 @@ public protocol ContentDecoder {
|
||||||
|
|
||||||
### URL クエリ
|
### URL クエリ
|
||||||
|
|
||||||
Vapor は、URL クエリ文字列のコンテンツを処理することができる coder のための 2 つのプロトコルを指定しています: `URLQueryDecoder` と `URLQueryEncoder`
|
Vapor は、URL クエリ文字列のコンテンツを処理することができるコーダーのための 2 つのプロトコルを指定しています: `URLQueryDecoder` と `URLQueryEncoder`
|
||||||
|
|
||||||
```swift
|
```swift
|
||||||
public protocol URLQueryDecoder {
|
public protocol URLQueryDecoder {
|
||||||
|
|
@ -254,7 +253,7 @@ extension HTML: ResponseEncodable {
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
`async`/`await` を使用している場合は、`AsyncResponseEncodable` を使用できます。
|
`async`/`await` を使用している場合は、`AsyncResponseEncodable` を使用できます。
|
||||||
|
|
||||||
```swift
|
```swift
|
||||||
extension HTML: AsyncResponseEncodable {
|
extension HTML: AsyncResponseEncodable {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue