1. Accept-language

优先级:1 > 2 > 3

  • 默认回滚

目标语言 > 英文 > 简体中文

👉能力说明

实现自动适配多语言功能

👉代码示例

  • 获取目标语言的方法

 export function getTargetLang(isSet?: boolean): string {
  if (window.__KDRIVE_INTERNATIONALITY_LANG__) {
    return window.__KDRIVE_INTERNATIONALITY_LANG__;
  }

  const urlLanguage = getUrlParams('lang'); // 最高优先级的语言:URL lang参数
  const cookieLanguage = getCookie('lang'); // 获取cookie中的lang
  const navigatorLanguage = window.navigator.language; // 获取浏览器语言
  let current: string = (urlLanguage || cookieLanguage || navigatorLanguage)?.toLocaleLowerCase();
  const isLanguageExist = !!current; // 是否配置了language

  switch (current) {
    case 'zh-hk':
    case 'zh-tw':
    case 'zh-mo':
      current = LANGUAGE_ENUM.ZH_HK;
      break;
    case 'zh-cn':
    case 'zh':
      current = LANGUAGE_ENUM.ZH_CN;
      break;
    default:
      current = isLanguageExist ? LANGUAGE_ENUM.EN_US : LANGUAGE_ENUM.ZH_CN;
      break;
  }

  if (isSet) {
    setCookie({
      key: 'lang',
      value: current === LANGUAGE_ENUM.ZH_HK ? LANGUAGE_ENUM.ZH_TW : current,
    });
  }

  window.__KDRIVE_INTERNATIONALITY_LANG__ = current;

  return current;
}
  • 配置翻译资源
H2WY2WY5ACQEI
  • en-US.json
{
  "menu": {
    "title": "Cross-network File Transfer",
    "description":"File Intranet/Extranet Transfer Tool"
  }
}
  • zh-CN.json

{
  "menu": {
    "title": "跨网文件传输",
    "description":"文件内外网传输工具"
  }
}
  • zh-HK.json

{
  "menu": {
    "title": "跨網文件傳輸",
    "description":"檔案內外網傳輸工具"
  }
}

多语言适配的初始化配置


import i18n from 'i18next';
import { initReactI18next } from 'react-i18next';
import us from './locales/en-US.json';
import cn from './locales/zh-CN.json';
import hk from './locales/zh-HK.json';
import { getTargetLang } from './utils/util';
/*
LANGUAGE_ENUM配置
export enum LANGUAGE_ENUM {
  ZH_CN = 'zh-CN',
  ZH_HK = 'zh-HK',
  EN_US = 'en-US',
  ZH_TW = 'zh-TW',
}
*/
import { LANGUAGE_ENUM } from '../../types/global';

// 获取目标语言
const targetLang = getTargetLang();

i18n.use(initReactI18next).init({
  resources: {
    [LANGUAGE_ENUM.EN_US]: { translation: us },
    [LANGUAGE_ENUM.ZH_CN]: { translation: cn },
    [LANGUAGE_ENUM.ZH_HK]: { translation: hk },
  },
  lng: targetLang,
  fallbackLng: LANGUAGE_ENUM.ZH_CN,
  supportedLngs: [LANGUAGE_ENUM.ZH_CN, LANGUAGE_ENUM.ZH_HK, LANGUAGE_ENUM.EN_US],
});

export default i18n;
  • 功能实现
  1. 在入口文件导入多语言适配的初始化配置文件
  2. 实现
  • 方案一:使用 i18next 的 t 方法实现

import i18n from 'i18next';

const kdrive = await sdk.kdrive;
kdrive.header.onMounted((data: any) => {
  data.isShow = true;
  data.appList.add({
    icon: folderImg,
    title: i18n.t('menu.title'),
    description: i18n.t('menu.description'),
    key: 'transform1',
  });
});
  • 方案二:在React中使用 react-i18next 的 useTranslation 方法

import React, { useEffect } from 'react';
import { useTranslation } from 'react-i18next';
import sdk from '../libs/sdk';
import folderImg from '../assets/filetransfer.png';

const Plugin = () => {
  const { t } = useTranslation();

  const addEntrance = async () => {
    // 这里插件按需异步加载资源报引入sdk.xxx
    const kdrive = await sdk.kdrive;
    kdrive.header.onMounted((data: any) => {
      data.isShow = true;
      data.appList.add({
        icon: folderImg,
        title: t('menu.title'),
        description: t('menu.description'),
        key: 'transform1',
      });
    });
  };

  useEffect(() => {
    addEntrance();
  }, []);

  return null;
};

export default React.memo(Plugin);

👉效果截图

  • 简体中文
G66LIWY5ADQCC
  • 英文
D2RLGWY5ADABO
  • 繁体中文
TFK3IWY5ABQAA

相关新闻

  • 登录密码页和访问到期页定制

    登录密码页和访问到期页定制

    针对设有密码的文件夹,企业可以定制密码登录页及访问到期页

    最佳实践 2025年12月11日
  • 限制用户下载特定文件

    限制用户下载特定文件

    在员工离职或出于其它安全考虑,企业需要对员工创建或管理的文件进行管控,或对扫描出敏感信息的文件进行管控,限制文件下载。 如何限制企业用户下载特定文件 本定制方案仅适用于私有化WPS365版本 1. 方案概述 员工离职前,出于安全考虑,企业会对其创建或管理的文件进行管控。 管控会有两个实现方式: 有安全管控需求时,比如文件扫描出敏感信息,用户的网络环境(内网或外网)、文件大小不满足管理规定,都有可能需要限制下载。 针对这两种情况,我们可以使用文档中心Web端(PC端)的开放能力,定制下载功能: 实…

    最佳实践 2025年12月11日
  • 扩展文件属性字段

    扩展文件属性字段

    企业需要在文件属性后打标签,方便后续查找和管理文件。

    最佳实践 2025年12月11日
  • 自定义云文档操作项

    自定义云文档操作项

    响应企业安全、效率需求,屏蔽、禁用、拦截、扩展云文档的导入导出等操作。 如何屏蔽\禁用\拦截\扩展文件操作项? 本定制方案仅适用于私有化WPS365版本 1. 方案概述 文档中心里,这些“新建”“导入”“上传”“导出”“分享”等按钮,都是文件操作项,企业用户可以使用这些按钮操作文件。 有些企业可能出于安全、效率等需求,希望屏蔽\禁用、拦截、扩展部分文件操作项。 屏蔽\禁用 指的是企业担心文档泄漏,希望完全禁止企业用户下载文档,想屏蔽\禁用WPS文档中心的下载按钮。屏蔽:指“操作项完全不可见”禁用…

    最佳实践 2025年12月11日
  • 告别Excel乱崩+电话催办!WPS 365,一键搭建任务预警平台,进度可视化、协作不内耗

    告别Excel乱崩+电话催办!WPS 365,一键搭建任务预警平台,进度可视化、协作不内耗

    🚨 任务太多没人交?3张表搞定进度监控!多维表格“动态预警平台”来了! “这个月的PPT谁还没交?”“预算表收齐了吗?我得一个个打电话问……”“又要手动统计,Excel一乱全崩了!” 你是不是也经历过这些? 作为管理者,最怕的就是: ✅ 任务安排下去,杳无音信 ✅ 每次催进度,都像“打地鼠” ✅ 手动汇总数据,一不小心就出错 别急!今天教你用 多维表格 搭建一个—— 👉 任务提交进度动态监管预警平台 无需代码、零成本,三张表打通闭环,实时看谁交了、谁没交、完成率多少! 🎯 为什么你需要这个系统?…

    企业数智化转型 2026年3月1日
  • 文档中心与第三方IM集成,促进高效协同办公

    文档中心与第三方IM集成,促进高效协同办公

    随着企业数字化转型的深入,企业在自研IM基础上需要补齐文档协作能力。文档中心通过集成第三方IM,为企业提供高效、安全的文档协作体验。 一、方案简介 金山办公文档中心V7集成第三方IM旨在为企业自研IM(即时通讯)系统提供文档能力的集成支持,通过文档中心V7与第三方IM的深度整合。 金山办公文档中心V7通过标准化接口与定制化开发相结合,实现IM与文档中心的无缝衔接,帮助企业构建”沟通-协作-管理”一体化平台。金山文档中心V7通过提供在线编辑、多人协同、版本管理,帮助客户减少…

    最佳实践 2025年12月11日

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

立即咨询 立即试用 上门服务

请您留言

感谢您的关注,你可留下联系方式,我们将第一时间与您联系。