0

0

JavaScript与Spring国际化支持的实现方法

蓮花仙者

蓮花仙者

发布时间:2025-11-09 18:06:02

|

1046人浏览过

|

来源于php中文网

原创

Spring通过资源文件和Locale解析器实现后端i18n,JavaScript通过接口获取语言包或使用国际化库实现前端多语言展示,两者通过统一locale格式、接口通信及协同策略实现完整国际化方案。

javascript与spring国际化支持的实现方法

实现国际化(i18n)需要前端后端协同工作,JavaScript 与 Spring 分别负责客户端和服务器端的多语言支持。以下是两者结合使用的常见实现方式。

Spring 后端国际化配置

Spring 提供了完整的 i18n 支持,通过资源文件和 Locale 解析器实现语言切换。

1. 创建消息资源文件

src/main/resources 下创建不同语言的 properties 文件:

立即学习Java免费学习笔记(深入)”;

  • messages.properties(默认)
  • messages_zh_CN.properties(中文)
  • messages_en_US.properties(英文)

例如:
messages_zh_CN.properties 内容:
welcome=欢迎使用系统
messages_en_US.properties 内容:
welcome=Welcome to the system

2. 配置 MessageSource 和 LocaleResolver

在 Spring 配置类或 XML 中注册相关 Bean:

@Bean
public MessageSource messageSource() {
    ResourceBundleMessageSource source = new ResourceBundleMessageSource();
    source.setBasename("messages");
    source.setDefaultEncoding("UTF-8");
    return source;
}

@Bean
public LocaleResolver localeResolver() {
    CookieLocaleResolver resolver = new CookieLocaleResolver();
    resolver.setDefaultLocale(Locale.SIMPLIFIED_CHINESE);
    resolver.setCookieName("lang");
    resolver.setCookieMaxAge(3600);
    return resolver;
}

3. 添加拦截器处理语言切换

通过 URL 参数(如 ?lang=en_US)切换语言:

@Override
protected void addInterceptors(InterceptorRegistry registry) {
    LocaleChangeInterceptor localeChangeInterceptor = new LocaleChangeInterceptor();
    localeChangeInterceptor.setParamName("lang");
    registry.addInterceptor(localeChangeInterceptor);
}

前端 JavaScript 国际化方案

JavaScript 可通过多种方式获取并显示对应语言内容,常见做法如下:

1. 从后端加载语言包

BiLin AI
BiLin AI

免费的多语言AI搜索引擎

下载

在页面初始化时,通过接口获取当前用户的语言文本:

fetch('/api/i18n/messages')
  .then(response => response.json())
  .then(data => {
    window.i18n = data; // 存储翻译映射
    document.getElementById('welcome').textContent = data['welcome'];
  });

Spring 控制器示例:

@GetMapping("/api/i18n/messages")
public Map<String, String> getMessages(
    HttpServletRequest request) {
    Locale locale = localeResolver.resolveLocale(request);
    Properties props = loadPropertiesForLocale(locale);
    return props.entrySet().stream()
        .collect(Collectors.toMap(
            e -> e.getKey().toString(),
            e -> e.getValue().toString()));
}

2. 使用 JS 国际化库(如 i18next 或 Globalize)

引入 i18next 并配合 AJAX 加载语言 JSON 文件:

i18next.use(XHR).init({
  lng: 'zh-CN',
  fallbackLng: 'en',
  backend: {
    loadPath: '/static/locales/{{lng}}/translation.json'
  }
}, function(err, t) {
  document.getElementById('welcome').textContent = t('welcome');
});

此时需将 Spring 的 messages 转为 JSON 格式输出,或单独维护前端语言文件。

3. 动态切换语言

提供语言选择按钮,发送请求并刷新界面:

function changeLang(lang) {
  fetch(`/api/i18n/change?lang=${lang}`, { method: 'GET' })
    .then(() => location.reload());
}

前后端协同最佳实践

为了提升体验和性能,建议采用以下策略:

  • 统一语言标识:前后端使用相同的 locale 格式(如 en_US、zh_CN)
  • 服务端渲染时直接注入语言文本,减少首屏请求
  • 静态资源使用独立语言包,避免每次请求都从后端读取
  • 对用户输入内容也做语言区分存储

基本上就这些。关键是让 Spring 管理语言资源和用户偏好,JavaScript 负责展示和交互,两者通过标准化接口通信,就能实现平滑的国际化体验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

161

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

89

2026.01.26

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6.1万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号