Vue-i18n踩坑记录

因为最近的一个Vue项目要上线国际版了,需要在中文版的基础上增加一个英文版。i18n虽然很方便,但还是有不少坑,记录在这里。

  1. 现在Vue-i18n12+版本还没有太好的支持,建议使用9+版本。
text 复制代码
npm install vue-i18n@9
  1. Vue-i18n是支持插值文本的,但插值用单括号。使用时用对象传入
js 复制代码
// en.ts
const en = {
    hint: "{ count } files in total, { selected } selected"
}
html 复制代码
<div class="selected-count">{{ t('upload.uploadTable.hint', {
        count: rows.length,
        selected: selectedFiles.length
    }) }}
</div>
  1. 列表渲染的中文文本在添加国际化后,不能用ref,ref也不能响应。必须用computed
js 复制代码
const headers = computed(() => [
    { label: t('upload.table.selected'), key: '已选择', width: '60px' },
    { label: t('upload.table.id'), key: 'id', width: '130px' },
    { label: t('upload.table.filename'), key: '文件名', width: '160px' },
    { label: t('upload.table.expireTime'), key: '过期时间', width: '130px' },
    { label: t('upload.table.operation'), key: '操作', width: '160px' }
])
  1. 大部分中文转英文后文本会变长,需要换行或改元素宽度
html 复制代码
<Button :width="locale === 'en' ? '130px' : '140px'" @click="handleConfirmUpload">
    {{t('upload.buttons.confirm')}}
</Button>
  1. 中文不需要考虑复数,英文还要加一层if判断,多于一个需要加复数

遇到问题再更新

相关推荐
kyriewen2 小时前
Anthropic 估值逼近万亿美元,Claude Sonnet 5 + Claude Science 一天两连发
前端·ai编程·claude
小徐_23334 小时前
Wot UI 2.2.0 发布:Button 新增 subtle,VideoPreview 预览体验继续增强
前端·微信小程序·uni-app
天蓝色的鱼鱼6 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷7 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花7 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷7 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜7 小时前
Spring Boot 核心知识点总结
前端
lichenyang4537 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕8 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js