Skip to main content

Translate

Less than 1 minute

Translate

Translate articals

Note

Don't use the machine translation directly!

Translate to new language

  1. Add localised configuration:

    1. Copy .vuepress/navbar/en.ts and name it .vuepress/navbar/lang.ts, add prefix /lang for all link and translate the contents of text:

      Example
      import { navbar } from "vuepress-theme-hope";
      
      export const navbarEn = navbar([
        {
          text: "Guide",
          link: "/guide/",
          icon: "creative",
        },
        {
          text: "Features",
          icon: "object",
          prefix: "/features/",
          children: [
            {
              text: "ES Standards",
              link: "es-standard/README.md",
              icon: "javascript",
            },
            {
              text: "ES Proposals",
              link: "es-proposal/README.md",
              icon: "proposal",
            },
            {
              text: "Web Standards",
              link: "web-standard/README.md",
              icon: "link",
            },
            {
              text: "Helpers",
              link: "helper/README.md",
              icon: "function",
            },
          ],
        },
        {
          text: "Contribution",
          prefix: "/dev/",
          icon: "tree",
          children: [
            {
              text: "Guide",
              icon: "question",
              link: "README.md",
            },
            {
              text: "Polyfill",
              icon: "code",
              link: "polyfill.md",
            },
            {
              text: "Compat Data",
              icon: "form",
              link: "compat.md",
            },
            {
              text: "Documents",
              icon: "article",
              link: "docs/README.md",
            },
          ],
        },
        {
          text: "Project",
          prefix: "/",
          icon: "more",
          children: [
            {
              text: "About",
              icon: "info",
              link: "project/README.md",
            },
            {
              text: "Changelog",
              icon: "time",
              link: "project/changelog.md",
            },
            {
              text: "Security",
              icon: "safe",
              link: "project/security.md",
            },
            {
              text: "Roadmap",
              icon: "state",
              link: "project/roadmap.md",
            },
            {
              text: "Blog",
              icon: "blog",
              link: "category/blog/",
            },
          ],
        },
        {
          text: "Compatibility",
          icon: "form",
          link: "/compat.md",
        },
        {
          text: "Sponsor",
          icon: "like",
          link: "/donate.md",
        },
      ]);
      
    2. Copy .vuepress/sidebar/en.ts and name it .vuepress/sidebar/lang.ts, replace "/" in line4 to "/lang/ and translate the contents of text:

      Example
      import { sidebar } from "vuepress-theme-hope";
      
      export const sidebarEn = sidebar({
        "/": [
          {
            text: "Guide",
            icon: "creative",
            prefix: "guide/",
            children: "structure",
            collapsible: true,
          },
          {
            text: "Features",
            icon: "object",
            prefix: "features/",
            children: [
              {
                text: "Overview",
                icon: "info",
                link: "README.md",
              },
              {
                text: "Missing Polyfills",
                icon: "notice",
                link: "missing-polyfills.md",
              },
              {
                text: "ES Standards",
                icon: "javascript",
                prefix: "es-standard/",
                children: "structure",
                collapsible: true,
              },
              {
                text: "ES Proposals",
                icon: "proposal",
                prefix: "es-proposal/",
                children: "structure",
                collapsible: true,
              },
              {
                text: "Web Standards",
                icon: "link",
                prefix: "web-standard/",
                children: "structure",
                collapsible: true,
              },
              {
                text: "Helpers",
                icon: "function",
                prefix: "helper/",
                children: "structure",
                collapsible: true,
              },
            ],
            collapsible: true,
          },
          {
            text: "Contribution",
            icon: "tree",
            prefix: "dev/",
            children: [
              {
                text: "How to contribute",
                icon: "question",
                link: "README.md",
              },
              {
                text: "Add a new polyfill",
                icon: "code",
                link: "polyfill.md",
              },
              {
                text: "Testing",
                icon: "check",
                link: "testing.md",
              },
              {
                text: "Update core-js-compat",
                icon: "form",
                link: "compat.md",
              },
              {
                text: "Writing documents",
                icon: "form",
                prefix: "docs/",
                children: [
                  {
                    text: "Writing documents",
                    icon: "form",
                    link: "README.md",
                  },
                  {
                    text: "Create doc for polyfill",
                    icon: "code",
                    link: "polyfill.md",
                  },
                  {
                    text: "Translate",
                    icon: "language",
                    link: "translate.md",
                  },
                ],
                collapsible: true,
              },
            ],
            collapsible: true,
          },
          {
            text: "Project",
            icon: "more",
            prefix: "project/",
            children: "structure",
            collapsible: true,
          },
          {
            text: "Sponsor",
            icon: "like",
            link: "donate.md",
          },
        ],
      });
      
    3. Add the language to locales field in .vuepress/config.ts:

      Example
      import { defineUserConfig } from "vuepress";
      import { getDirname, path } from "@vuepress/utils";
      import i18nPlugin from "vuepress-plugin-i18n";
      import { redirectPlugin } from "vuepress-plugin-redirect";
      import searchPlugin from "@vuepress/plugin-search";
      import shikiPlugin from "@vuepress/plugin-shiki";
      import theme from "./theme.js";
      import { version } from "../../packages/core-js/package.json";
      
      const __dirname = getDirname(import.meta.url);
      export default defineUserConfig({
        lang: "en-US",
        description: "Modular standard library for JavaScript",
        locales: {
          "/": {
            lang: "en-US",
            title: "Core-JS Document",
            description: "Modular standard library for JavaScript",
          },
          "/zh/": {
            lang: "zh-CN",
            title: "Core-JS 文档",
            description: "模块化 JavaScript 标准库",
          },
        },
        theme,
        alias: {
          "@compat-tests": () =>
            path.resolve(__dirname, "..", "..", "tests", "compat", "tests.js"),
        },
        markdown: {
          importCode: {
            handleImportPath: (str) =>
              str.replace(/^@docs-root/, path.resolve(__dirname, "..")),
          },
        },
        plugins: [
          i18nPlugin({
            translationGuide: "/dev/docs/translate.html",
            updatedTime: "file",
          }),
          searchPlugin(),
          shikiPlugin({
            theme: "one-dark-pro",
          }),
          redirectPlugin({
            localeConfig: {
              "/": ["en-US", "en-UK", "en"],
              "/zh/": ["zh-CN", "zh-TW", "zh"],
            },
            switchLocale: "modal",
          }),
        ],
        extendsPage: (page) => {
          if (page.sfcBlocks.template?.contentStripped)
            page.sfcBlocks.template.contentStripped =
              page.sfcBlocks.template.contentStripped.replaceAll(
                "3.31.1",
                version
              );
        },
      });
      














       
       
       













































    4. Import the navbar&sidebar and add the language to locales field in .vuepress/theme.ts:

      Example
      import { hopeTheme } from "vuepress-theme-hope";
      import { navbarEn, navbarZh } from "./navbar/index.js";
      import { sidebarEn, sidebarZh } from "./sidebar/index.js";
      
      export default hopeTheme(
        {
          favicon: "logo.png",
          repo: "https://github.com/zloirock/core-js",
          docsBranch: "master",
          docsDir: "docs",
          iconAssets: "iconfont",
          locales: {
            "/": {
              navbar: navbarEn,
              sidebar: sidebarEn,
              copyright: `© 2014-${new Date().getFullYear()} Core-JS contributors`,
            },
            "/zh/": {
              navbar: navbarZh,
              sidebar: sidebarZh,
              copyright: `© 2014-${new Date().getFullYear()} Core-JS 贡献者`,
            },
          },
          displayFooter: true,
          plugins: {
            autoCatalog: {
              locales: {
                "/": { title: "Index" },
                "/zh/": { title: "索引" },
              },
            },
            blog: true,
            mdEnhance: {
              attrs: true,
              tabs: true,
              imgLazyload: true,
              include: true,
              tasklist: true,
              codetabs: true,
            },
            prismjs: false,
          },
        },
        {
          custom: true,
        }
      );
      

       
       










       
       
       
       






























  2. Translate the content of the document