vue3 element-plus i18n form表单校验 rules message i18n 不生效

刚开始的效果是

在这里插入图片描述

const loginRules = {
  username: [{ required: true, trigger: "blur", message: t('login.pleaseEnterYourAccount') }],
  password: [{ required: true, trigger: "blur", message: t('login.pleaseEnterYourPassword') }],
  code: [{ required: true, trigger: "change", message: t('login.pleaseEnterVerificationCode') }]
};

后续发先不对劲这怎么改都改不动发现是数据没热更新
用了computed去写
发现会有问题会导致会有双引号在这里插入图片描述

const pleaseEnterYourAccount = computed(() => t('login.pleaseEnterYourAccount'))
const pleaseEnterYourPassword = computed(() => t('login.pleaseEnterYourPassword'))
const pleaseEnterVerificationCode = computed(() => t('login.pleaseEnterVerificationCode'))
const loginRules = computed(() => ({
  username: [{ required: true, trigger: "blur", message: pleaseEnterYourAccount}],
  password: [{ required: true, trigger: "blur", message: pleaseEnterYourPassword}],
  code: [{ required: true, trigger: "change", message: pleaseEnterVerificationCode}],
}))

直接用computed包住整个校验
在这里插入图片描述

const loginRules = computed(() => ({
  username: [{ required: true, trigger: "blur", message: t('login.pleaseEnterYourAccount') }],
  password: [{ required: true, trigger: "blur", message: t('login.pleaseEnterYourPassword') }],
  code: [{ required: true, trigger: "change", message: t('login.pleaseEnterVerificationCode') }]
}))

完美解决

Element Plus 是一个基于 Vue.js 的 UI 组件库,用于构建 Web 应用程序的用户界面。它提供了丰富的组件和功能,支持国际化(i18n)。 Element Plus 支持多语言国际化,可以根据用户的语言环境切换界面显示的语言。在 Element Plus 中,你可以使用 Vue I18n 来实现国际化功能。Vue I18n 是一个 Vue.js 的插件,用于处理国际化。 要在 Element Plus 中使用国际化功能,你需要先引入 Vue I18n,并配置需要翻译的文字内容和对应的翻译文本。然后,在组件中使用 `$t` 方法来获取翻译后的文字。 以下是一个简单的示例: ```javascript // main.js import { createApp } from 'vue' import ElementPlus from 'element-plus' import locale from 'element-plus/lib/locale/lang/zh-cn' // 引入中文语言包 import { createI18n } from 'vue-i18n' const messages = { 'zh-cn': { // 中文翻译 hello: '你好', ... }, 'en-us': { // 英文翻译 hello: 'Hello', ... }, } const i18n = createI18n({ locale: 'zh-cn', // 默认语言为中文 messages, }) createApp(App) .use(ElementPlus, { locale }) // 使用 Element Plus 并传入中文语言包 .use(i18n) // 使用 Vue I18n .mount('#app') ``` ```vue <!-- HelloWorld.vue --> <template> <div>{{ $t('hello') }}</div> </template> ``` 在上述示例中,我们在 main.js 中引入了 Element Plus 和 Vue I18n,并配置了中文和英文的翻译内容。然后在组件中使用 `$t` 方法来获取翻译后的文字。 这样,当用户的语言环境设置为中文时,页面将显示"你好";当语言环境设置为英文时,页面将显示"Hello"。你可以根据自己的需求添加更多的语言翻译内容。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值