react 国际化

  • 组件库的国际化 import { ConfigProvider } from 'antd' // 引入语言包 import zhCN from 'antd/lib/locale/zh_CN'; import enUS from 'antd/lib/locale/en_US';

    const langs:any = {
      'zh-CN':zhCN,
      'en-US':enUS
    }
    
    // 注入
    <ConfigProvider locale={langs[lang]}>
    	<System />
    </ConfigProvider>
    
  • react-intl 国际化配置 import zhCNi from '@/lang/zhCNi' import enUSi from '@/lang/enUSi'

    // 定义语言包
    const langsi:any = {
      'zh-CN':zhCNi,
      'en-US':enUSi
    }
    
    //注入 locale :当前语言 messages:语言包
    <IntlProvider locale={ lang } messages={langsi[lang]}> 
       <ConfigProvider locale={langs[lang]}>
            <System />
       </ConfigProvider>
    </IntlProvider>
    
    // 使用FormattedMessage api 指定语言id
    <div><FormattedMessage id='article.title'></FormattedMessage></div>
        
    
  • 自定义上下文 实现 import React, { PureComponent, useContext } from 'react'

    // 创建上下文
    const LangContext = React.createContext(null)
    const LangProvider = LangContext.Provider
    const LangConsumer = LangContext.Consumer
    
    function injectLang(C:any) {
        return class extends PureComponent {
          render() {
            return (
              // 消费
              <LangConsumer>
              {
                lang => (
                  <C {...this.props} lang={lang} />
                )
              }
              </LangConsumer>
            )
          }
        }
      }
    
    function useLang() {
        const lang = useContext(LangContext)
        return lang
    }
    
    export {
        LangProvider,
        injectLang,
        useLang
    }
    
    // 提供消费
    const langsi:any = {
      'zh-CN':zhCNi,
      'en-US':enUSi
    }
    
     <LangProvider value={langsi[lang]}>
         <System />
     </LangProvider>
    
    
    // 使用
    const lang:any = useLang()
    
    console.log('自定义国际化的lang----', lang);
    
    <div>{lang['article.title']}</div>
    
全部评论

相关推荐

2024-12-09 17:16
海南大学 Java
点赞 评论 收藏
分享
黑皮白袜臭脚体育生:简历条例统一按使用了什么技术实现了什么功能解决了问题或提升了什么性能指标来写会好些,如使用布隆过滤器实现了判断短链接是否存在,大大提升了查询速度
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务