此页面的内容已使用 AI 翻译。

    查看英文原文的最新版本

    文件内容 / 在 Intlayer 中嵌入文件

    文件嵌入的工作原理

    在 Intlayer 中,file 函数允许将外部文件内容嵌入到字典中。这种方法确保 Intlayer 识别源文件,从而实现与 Intlayer 可视化编辑器和 CMS 的无缝集成。与直接使用 importrequirefs 文件读取方法不同,使用 file 将文件与字典关联,使 Intlayer 能够在文件编辑时动态跟踪和更新内容。

    设置文件内容

    要在 Intlayer 项目中嵌入文件内容,请在内容模块中使用 file 函数。以下是展示不同实现方式的示例。

    TypeScript 实现

    **/*.content.ts
    import { file, type Dictionary } from "intlayer";const myFileContent = {  key: "my_key",  content: {    myFile: file("./path/to/file.txt"),  },} satisfies Dictionary;export default myFileContent;

    ECMAScript 模块 (ESM) 实现

    CommonJS 实现

    JSON 配置

    在 React Intlayer 中使用文件内容

    要在 React 组件中使用嵌入的文件内容,请从 react-intlayer 包中导入并使用 useIntlayer 钩子。此钩子从指定的键中检索内容,并允许动态显示。

    **/*.tsx
    import type { FC } from "react";import { useIntlayer } from "react-intlayer";const FileComponent: FC = () => {  const { myFile } = useIntlayer("my_key");  return (    <div>      <pre>{myFile}</pre>    </div>  );};export default FileComponent;

    多语言 Markdown 示例

    要支持多语言可编辑的 Markdown 文件,可以将 filet()md() 结合使用,以定义 Markdown 内容文件的不同语言版本。

    **/*.content.ts
    import { file, t, md, type Dictionary } from "intlayer";const myMultilingualContent = {  key: "my_multilingual_key",  content: {    myContent: md(      t({        zh: file("src/components/test.zh.md"),        en: file("src/components/test.en.md"),        fr: file("src/components/test.fr.md"),        es: file("src/components/test.es.md"),      })    ),  },} satisfies Dictionary;export default myMultilingualContent;

    此设置允许根据用户的语言偏好动态检索内容。当在 Intlayer 可视化编辑器或 CMS 中使用时,系统将识别内容来自指定的 Markdown 文件,并确保它们保持可编辑。

    Intlayer 如何处理文件内容

    file 函数基于 Node.js 的 fs 模块读取指定文件的内容并将其插入到字典中。当与 Intlayer 可视化编辑器或 CMS 一起使用时,Intlayer 可以跟踪字典与文件之间的关系。这使得 Intlayer 能够:

    • 识别内容来源于特定文件。
    • 在链接文件被编辑时自动更新字典内容。
    • 确保文件与字典之间的同步,保持内容的完整性。

    其他资源

    有关在 Intlayer 中配置和使用文件嵌入的更多详细信息,请参考以下资源:

    这些资源提供了有关文件嵌入、内容管理以及 Intlayer 与各种框架集成的更多见解。

    如果您有改善此文档的想法,请随时通过在GitHub上提交拉取请求来贡献。

    文档的 GitHub 链接