\n\n \n ```\n\n \n \n ```svelte fileName=\"FAQ.svelte\"\n \n\n \n ```\n\n \n \n ```tsx fileName=\"FAQ.tsx\"\n import { useIntlayer } from \"preact-intlayer\";\n\n export const FAQ = () => {\n const items = useIntlayer(\"faq\"); // { question: string; answer: string }[]\n\n return (\n \n );\n };\n ```\n\n \n \n ```tsx fileName=\"FAQ.tsx\"\n import { useIntlayer } from \"solid-intlayer\";\n import { For } from \"solid-js\";\n\n export const FAQ = () => {\n const items = useIntlayer(\"faq\"); // { question: string; answer: string }[]\n\n return (\n \n );\n };\n ```\n\n \n \n ```typescript fileName=\"faq.component.ts\"\n import { Component } from \"@angular/core\";\n import { useIntlayer } from \"angular-intlayer\";\n\n @Component({\n selector: \"app-faq\",\n template: `\n \n `,\n })\n export class FAQComponent {\n items = useIntlayer(\"faq\");\n }\n ```\n\n \n \n ```javascript fileName=\"faq.js\"\n import { useIntlayer } from \"vanilla-intlayer\";\n\n const faq = useIntlayer(\"faq\");\n\n faq.forEach((item) => {\n console.log(item.question);\n console.log(item.answer);\n });\n ```\n\n \n\n\n### インデックスによる単一アイテムの取得\n\n```tsx\nconst faq2 = useIntlayer(\"faq\", { item: 2 });\n// → { question: string; answer: string }\n```\n\n### ロケールを明示した単一アイテムの取得\n\n```tsx\nconst faq2Ja = useIntlayer(\"faq\", { item: 2, locale: \"ja\" });\n```\n\n## 一般的なユースケース\n\n- FAQ(よくある質問)リスト\n- 料金プラン\n- カルーセル / スライダーの画像・コンテンツ\n- ステップ形式のチュートリアル・説明\n","description":"Intlayerのコンテンツファイルでitemメタデータフィールドを使用して、ランタイムにインデックスで選択可能な、ローカライズされたアイテムの順序付きコレクションを構築します。","url":"https://intlayer.org/ja/doc/concept/collections","datePublished":"2026-06-12","dateModified":"2026-06-12","version":"9.0.0","keywords":"コレクション, コンテンツリスト, 動的コンテンツ, Intlayer, 国際化","license":"https://raw.githubusercontent.com/aymericzip/intlayer/refs/heads/main/LICENSE","audience":{"@type":"Audience","audienceType":"開発者、コンテンツマネージャー"}}
    著者:
    作成:2026-06-12最終更新:2026-06-12

    コレクション

    コレクション(Collection)は、同じディクショナリキー(key)を共有するものの、それぞれ異なる item インデックスを宣言するコンテンツファイルの集合です。Intlayerはビルド時にこれらを1つの順序付きリストにマージします。

    コレクションアイテムの宣言

    各ファイルは1つのアイテムを表します。item フィールドは、リスト内での位置を表します(1から開始)。

    faq.1.content.ts
    import { t, type Dictionary } from "intlayer";
    
    const dictionary = {
      key: "faq",
      item: 1,
      content: {
        question: t({ en: "What is Intlayer?", fr: "Qu'est-ce qu'Intlayer ?" }),
        answer: t({ en: "An i18n toolkit.", fr: "Une boîte à outils i18n." }),
      },
    } satisfies Dictionary;
    
    export default dictionary;
    faq.2.content.ts
    import { t, type Dictionary } from "intlayer";
    
    const dictionary = {
      key: "faq",
      item: 2,
      content: {
        question: t({ en: "Is it free?", fr: "Est-ce gratuit ?" }),
        answer: t({ en: "Yes, open-source.", fr: "Oui, open-source." }),
      },
    } satisfies Dictionary;
    
    export default dictionary;

    コレクションの利用

    すべてのアイテム

    FAQ.tsx
    import { useIntlayer } from "react-intlayer";export const FAQ = () => {  const items = useIntlayer("faq"); // { question: string; answer: string }[]  return (    <ul>      {items.map((item, index) => (        <li key={index}>          <strong>{item.question}</strong>          <p>{item.answer}</p>        </li>      ))}    </ul>  );};

    インデックスによる単一アイテムの取得

    tsx
    const faq2 = useIntlayer("faq", { item: 2 });// → { question: string; answer: string }

    ロケールを明示した単一アイテムの取得

    tsx
    const faq2Ja = useIntlayer("faq", { item: 2, locale: "ja" });

    一般的なユースケース

    • FAQ(よくある質問)リスト
    • 料金プラン
    • カルーセル / スライダーの画像・コンテンツ
    • ステップ形式のチュートリアル・説明