react-intl国际化踩坑记录

最近的项目中有国际化的需求,经过调研之后决定使用react-intl进行。特地记录一下开发中需要注意的点及踩过的坑。

1.在class组件中如何使用以及ts类型的声明

通常在函数组件中我们直接通过useIntl这个钩子函数来使用,但是在class组件中是没法使用钩子函数的。这个时候就需要用到react-intl提供的另外一个方法injectIntl。具体使用方法如下

// 定义的props要继承react-intl的WrappedComponentProps
interface ICommonDialogProps extends WrappedComponentProps<"intl"> {}

class CommonDialog extends React.Component<ICommonDialogProps, ICommonDialogState>{
    render(){
        return <div>{this.props.intl.formatMessage({id: "", defaultMessage: ""})}<div>
    }
}

// 通过injectIntl这个高阶组件将intl注入到我们的组件中去
export default injectIntl(CommonDialog);

injectIntl是react-intl暴露出来的一个高阶组件,将intl对象注入到组件中去。

2.模板标签的使用

实际的项目开发中不可能只有简单的文字转换,有时可能会涉及到特殊文本的转换例如:aaa<span>bbb</span>ccc,这个时候需要将bbb单独转换,代码如下:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值