【从0搭建react后台管理】5.引入国际化i18next组件

【项目地址】
https://gitee.com/shangqiao1996/member-points-mgmt


1. 安装
  • 安装依赖 npm i react-i18next i18next --S
2. 配置国际化
  • 创建文件:i18n/zh.js
export default {
  username: "用户名",
  password: "密码",
};
  • 创建文件:i18n/en.js
export default {
  username: "username",
  password: "password",
};
  • 创建文件:i18n/index.js
import i18n from "i18next";
import { initReactI18next } from "react-i18next";
import zh from "./zh";
import en from "./en";

const resources = {
  en: {
    translation: en,
  },
  zh: {
    translation: zh,
  },
};

i18n.use(initReactI18next).init({
  resources,
  fallbackLng: "zh",
  lng: "zh",
  debug: true,
  interpolation: {
    escapeValue: false, // not needed for react as it escapes by default
  },
});

export default i18n;
3. 在入口文件 index.js 中引用启用
import "./i18n";
4.使用
  1. 类组件中使用:
    使用 withTranslation()高阶组价包裹容器组件。
import { withTranslation } from "react-i18next";

class HomeLayout extends Component {
  constructor(props) {
    super(props);
    this.t = props.t;
  }
  render() {
    return <div>{this.t("username")}</div>;
  }
}

export default withTranslation()(HomeLayout);
  1. 函数组件中使用:
import { useTranslation } from 'react-i18next';

export default (props) => {
  const { t } = useTranslation();

  return {
    <div>{t('username')}</div>
  }
}
  1. 切换语言
    i18n.language:获取当前环境语言
    i18n.changeLanguage():切换语言
import i18n from "i18next";

switchLang = () => {
  const lang = i18n.language;
  if (lang === "zh") {
    i18n.changeLanguage("en");
  } else {
    i18n.changeLanguage("zh");
  }
};
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雪 风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值