微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vue 3 + vue-i18n-next:我做错了什么?

如何解决Vue 3 + vue-i18n-next:我做错了什么?

我已经开始了一个 Vue 3 项目(目前只不过是一个带有 TypeScript 的样板)并尝试向其中添加 i18n。

据我所知,vue-i18n 在 Vue 3 中不能正常工作;但是 vue-i18n-next 应该。

这是我的 main.ts

import { createApp } from "vue";
import "./registerServiceWorker";
import router from "./router";
import store from "./store";
import { createI18n } from 'vue-i18n'
import App from "./App.vue";

//import en from "./locale/en.json"
//import ru from "./locale/ru.json"

const messages = {
    en: {
        message: {
            hello: 'hello world'
        }
    },ru: {
        message: {
            hello: 'Таки здравствуйте'
        }
    }
}

const i18n = createI18n({
    locale: 'ru',/*    messages: {
        en,ru
        },*/
    messages,fallbackLocale: 'en'
})

const app = createApp(App)
    .use(store)
    .use(router)
    .use(i18n);
    .mount("#app");

这是我的 App.vue

<template>
  <div id="nav">
    <router-link to="/">Home</router-link> |
    <router-link to="/about">About</router-link>
  </div>
  <div>{{ $t("message.hello") }}</div>
  <router-view />
</template>

但是,我收到警告

[intlify] The message format compilation is not supported in this build. Because message compiler isn't included. You need to pre-compilation all message format. So translate function return 'message.hello'.

确实我已经找到并安装了@intlify/message-compiler - 但不知道如何使用它。

我的 webpack.config.js 取自示例

const path = require("path");
module.exports = {
  rules: [
    {
      test: /\.(json5?|ya?ml)$/,// target json,json5,yaml and yml files
      type: "javascript/auto",loader: "@intlify/vue-i18n-loader",include: [
        // Use `Rule.include` to specify the files of locale messages to be pre-compiled
        path.resolve(__dirname,"./src/locale"),],},};

我的 vue.config.js 看起来很简单

module.exports = {
  chainWebpack: (config) => {
    config.plugin("html").tap((args) => {
      args[0].template = "./resources/index.html";
      return args;
    });
  },configureWebpack: {
    devServer: {
      watchOptions: {
        ignored: ["/node_modules/","/public/","**/.#*"],parallel: true,devServer: {
    disableHostCheck: true,public: process.env.DEV_PUBLIC ?? "mlb.ru",port: process.env.DEV_PORT ?? 8080,};

我什至发现我的消息已经被编译成bundle。

也许有人在 vue-18n-next 或其他一些适用于 Vue 3 的 i18n 解决方案方面取得了成功?

解决方法

存储库和文档已移动:

https://github.com/intlify/vue-i18n-next 我尝试了一个非常相似的代码,只要你在 vue-i18n@9.0.0-beta.16import { createI18n } from 'vue-i18n' 就应该对你有用

... [code]

import { createI18n } from 'vue-i18n'

const messages = {
  es: {
    message: {
      value: 'Hola Español.',},en: {
    message: {
      value: 'Hello English.',}

const i18n = createI18n({
  locale: 'es',messages,})

app
  .use(i18n)
  .mount('#app')

[code] ...
,

与 Vue 本身一样,i18n 包带有各种版本。与 Vue 一样,它们也有带和不带运行时编译器的版本。来自the docs

vue-i18n.esm-bundler.js:包括运行时编译器。如果您正在使用捆绑器但仍希望编译区域设置消息(例如通过内联 JavaScript 字符串的模板),请使用此选项

您收到的警告显然是在告诉您需要此编译器版本。文档对此不太清楚,但您需要将导入指向包的运行时编译器版本,如下所示:

import { createI18n } from "vue-i18n/dist/vue-i18n.esm-bundler.js";
,

我在外部文件 (i18n.js) 中使用 i18n 希望对您有所帮助。

i18n.js

.input-w label,.input-w select {
    vertical-align: middle;
    display: block;
}

.label {
    padding: 0.21em 0.4em 0.2em;
    box-shadow: none;
    float: left;
}

.select-input{
  float: right;
}

ma​​in.js

import { createI18n } from 'vue-i18n'
const messages = {
    en: {
        message: {
            hello: 'hello world'
        }
    },ru: {
        message: {
            hello: 'Таки здравствуйте'
        }
    }
}
const i18n = createI18n({
    locale: 'en',messages
})
export default i18n

App.vue

import { createApp } from 'vue'
import App from './App.vue'
import i18n from "@/i18n"
const app = createApp(App)
app.use(i18n)
app.mount('#app')

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。