Go で構造体を操作する場合、異なるコンテキストで同じフィールドを表すために複数の名前タグを定義すると便利です。これは、特定の形式のデータを必要とするサードパーティのライブラリや API を扱う場合に特に便利です。
次の例を考えてみましょう:
type Page struct { PageId string `bson:"pageId"` Meta map[string]interface{} `bson:"meta"` }
この構造体は、MongoDB (bson) のタグが付けられた PageId フィールドを持つ Mongo データベース ドキュメントを表すように設計されています。 MongoDB 用にタグ付けされた Meta フィールドも同様です。ただし、この構造体を JSON にエンコードすると、PageId フィールドは pageId ではなく PageId (大文字) としてレンダリングされます。
1 つのオブジェクトに複数の名前タグを定義するにはフィールドでは、タグ間の区切り文字としてカンマの代わりにスペースを使用します。構造体の更新バージョンは次のとおりです。
type Page struct { PageId string `bson:"pageId" json:"pageId"` Meta map[string]interface{} `bson:"meta" json:"meta"` }
この変更により、PageId フィールドは MongoDB (pageId として) と JSON (pageId として) の両方でタグ付けされます。これにより、MongoDB と対話するとき、または JSON にエンコードするときに、フィールドに適切な名前が付けられるようになります。
Go リフレクト パッケージのドキュメントでは、タグ文字列の規則が指定されています。
By convention, tag strings are a concatenation of optionally space-separated key:"value" pairs.
以上がGo 構造体のフィールドに複数の名前タグを定義するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。