{
  "url": "https://unifast.dev/ja/docs/packages/core/extract-lang/",
  "locale": "ja",
  "title": "extractLang()",
  "description": "code 要素の className からプログラミング言語を抽出します。",
  "section": "packages",
  "body": "```ts\nimport { extractLang } from \"@unifast/core\";\n```\n\n## シグネチャ\n\n```ts\nfunction extractLang(code: HastElement): string | null\n```\n\n## パラメータ\n\n### code\n\n| プロパティ | 型 | デフォルト | 説明 |\n|----------|------|---------|-------------|\n| `type` | `\"element\"` | — | ノード種別の識別子 |\n| `tagName` | `string` | — | HTML のタグ名 (通常は `\"code\"`) |\n| `properties` | `Record<string, unknown>` | — | `className` を含む要素のプロパティ |\n| `children` | `HastNode[]` | — | 要素の子ノード |\n\n## 戻り値\n\n`string | null` — 最初の `language-*` クラスから抽出された言語識別子です。言語クラスが見つからない場合は `null` を返します。\n\n## 使い方\n\n```ts\nimport { extractLang } from \"@unifast/core\";\nimport type { HastElement } from \"@unifast/core\";\n\nconst codeElement: HastElement = {\n  type: \"element\",\n  tagName: \"code\",\n  properties: { className: [\"language-typescript\"] },\n  children: [{ type: \"text\", value: \"const x = 1;\" }],\n};\n\nconst lang = extractLang(codeElement);\n\nconsole.log(lang);\n// typescript\n```\n\n## 使用例\n\n### code 要素から言語を抽出する\n\n```ts\nimport { extractLang } from \"@unifast/core\";\nimport type { HastElement } from \"@unifast/core\";\n\nconst code: HastElement = {\n  type: \"element\",\n  tagName: \"code\",\n  properties: { className: [\"language-js\", \"highlight\"] },\n  children: [{ type: \"text\", value: \"console.log('hello');\" }],\n};\n\nconsole.log(extractLang(code));\n// js\n```\n\n### 言語クラスがない場合\n\n```ts\nimport { extractLang } from \"@unifast/core\";\nimport type { HastElement } from \"@unifast/core\";\n\nconst code: HastElement = {\n  type: \"element\",\n  tagName: \"code\",\n  properties: { className: [\"highlight\"] },\n  children: [{ type: \"text\", value: \"plain text\" }],\n};\n\nconsole.log(extractLang(code));\n// null\n```\n\n### className が配列でない場合\n\n```ts\nimport { extractLang } from \"@unifast/core\";\nimport type { HastElement } from \"@unifast/core\";\n\nconst code: HastElement = {\n  type: \"element\",\n  tagName: \"code\",\n  properties: {},\n  children: [{ type: \"text\", value: \"no classes\" }],\n};\n\nconsole.log(extractLang(code));\n// null\n```\n\n### findCodeChild と組み合わせて使う\n\n```ts\nimport { extractLang, findCodeChild } from \"@unifast/core\";\nimport type { HastElement } from \"@unifast/core\";\n\nconst pre: HastElement = {\n  type: \"element\",\n  tagName: \"pre\",\n  properties: {},\n  children: [\n    {\n      type: \"element\",\n      tagName: \"code\",\n      properties: { className: [\"language-python\"] },\n      children: [{ type: \"text\", value: \"print('hello')\" }],\n    },\n  ],\n};\n\nconst code = findCodeChild(pre);\nif (code) {\n  console.log(extractLang(code));\n  // python\n}\n```",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/ja/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/zh-CN/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/zh-TW/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/ko/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/fr/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/it/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/es/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/pt-BR/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/de/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/ru/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/hi/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/id/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/tr/docs/packages/core/extract-lang.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/packages/core/extract-lang/",
      "api": "https://unifast.dev//api/vi/docs/packages/core/extract-lang.json"
    }
  ]
}
