【发布时间】:2021-08-31 14:56:16
【问题描述】:
我有一个项目需要在 Vuex 商店内进行翻译。但是在商店内尝试使用 i18n 进行翻译时,我不断收到错误消息。
我尝试使用以下导入语句在商店中导入 i18n 的实例。但是我得到一个错误Uncaught TypeError: _i18n__WEBPACK_IMPORTED_MODULE_3__.default.t is not a function
import i18n from '@/i18n';
在我的 Vue 项目的 main.js 文件中,我导入并使用 i18n 文件:
import { createApp } from 'vue';
import App from './App.vue';
import router from './router';
import { store } from './store';
import i18n from './i18n';
createApp(App).use(i18n).use(store).use(router).mount('#app');
这是我的 i18n.js 文件,位于 src 文件夹内:
import { createI18n } from 'vue-i18n';
function loadLocaleMessages() {
const locales = require.context(
'./locales',
true,
/[A-Za-z0-9-_,\s]+\.json$/i
);
const messages = {};
locales.keys().forEach((key) => {
const matched = key.match(/([A-Za-z0-9-_]+)\./i);
if (matched && matched.length > 1) {
const locale = matched[1];
messages[locale] = locales(key);
}
});
return messages;
}
export default createI18n({
legacy: false,
locale: localStorage.locale ?? 'nl',
globalInjection: true,
messages: loadLocaleMessages(),
});
【问题讨论】:
标签: javascript vue.js internationalization vue-i18n