前端I18n的使用

1.安装依赖

pnpm install vue-i18n

2.创建国际化配置文件

        在 src 目录下创建一个 locales 文件夹,并在其中创建不同语言的翻译文件,例如 en.jsonzh.json

{
  "demo": {
    "hello": "hello"
  }
}
{
  "demo": {
    "hello": "你好"
  }
}

3.配置 Vue I18n

        在 src 目录下创建一个plugins文件夹,并在其中创建 i18n.ts 文件,并在其中配置 Vue I18n。

import { createI18n } from 'vue-i18n'

// 导入翻译文件
import en from '@/locales/en.json'
import zh from '@/locales/zh.json'

// 创建 Vue I18n 实例
const i18n = createI18n({
  legacy: false, // 使用 composition 模式
  locale: 'zh', // 设置默认语言
  fallbackLocale: 'en', // 设置回退语言
  globalInjection: true, // 允许全局注入
  messages: {
    en,
    zh
  }
})

export default i18n

4.在主文件中引入 Vue I18n

// main.ts

import { createApp } from 'vue'
import App from './App.vue'
import i18n from '@/plugins/i18n'

const app = createApp(App)

app.use(i18n)

app.mount('#app')

5.使用i18n-ally插件

①下载插件i18n-ally

②配置.vscode -> settings.json

{
  "i18n-ally.localesPaths": ["src/locales"],
  "i18n-ally.displayLanguage": "zh",
  "i18n-ally.namespace": true,
  "i18n-ally.pathMatcher": "{locale}.json",
  "i18n-ally.keystyle": "nested",
  "i18n-ally.sourceLanguage": "zh" //locale对应国际化语言
}

6.在组件中使用 Vue I18n

<template>
  <div>
    <p>你好</p>
    <button @click="changeLanguage('en')">英文</button>
    <button @click="changeLanguage('zh')">中文</button>
  </div>
</template>

<script lang="ts" setup>
import { useI18n } from "vue-i18n";

const { locale } = useI18n();

const changeLanguage = (lang: string) => {
  locale.value = lang;
};
</script>

点击新路径

中文配置完成,可以在框选处编辑英文部分,或者在en.jsonzh.json 编辑改写

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Spring Boot中,我们可以通过自定义拦截器来实现获取前端i18n语言参数的封装。 首先,在前端部分,我们可以将i18n语言参数保存在Cookie中,代码如下: ```javascript document.cookie = "language=en-US; path=/"; ``` 然后,在后端部分,我们需要自定义一个拦截器,在拦截器中获取Cookie中的i18n语言参数,并将其保存在本地线程中。代码如下: ```java public class LanguageInterceptor implements HandlerInterceptor { private static final ThreadLocal<String> languageHolder = new ThreadLocal<>(); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if ("language".equals(cookie.getName())) { languageHolder.set(cookie.getValue()); return true; } } } // 如果Cookie中没有i18n语言参数,则默认使用英文 languageHolder.set("en-US"); return true; } public static String getLanguage() { return languageHolder.get(); } public static void clearLanguage() { languageHolder.remove(); } } ``` 注意,如果Cookie中没有i18n语言参数,则默认使用英文。 接着,在Spring Boot的配置文件中注册这个拦截器,并配置它的拦截路径。代码如下: ```java @Configuration public class InterceptorConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new LanguageInterceptor()).addPathPatterns("/**"); } } ``` 最后,在我们的业务逻辑中,我们可以通过调用`LanguageInterceptor.getLanguage()`方法来获取i18n语言参数。代码如下: ```java @RestController public class ExampleController { @GetMapping("/") public String hello() { String language = LanguageInterceptor.getLanguage(); // do something with language return "Hello"; } } ``` 同样,需要注意的是,在业务逻辑中,我们需要在使用i18n语言参数后,调用`LanguageInterceptor.clearLanguage()`方法来清除本地线程中的数据,以避免内存泄漏。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值