资源国际化

一、介绍:

1.软件的国际化:软件开发时,要使它能同时应对世界不同地区和国家的访问,并针对不同地区和国家的访问,提供相应的、符合来访者阅读习惯的页面或 数据

   2.国际化又称为 i18n:internationalization

   3.固定文本元素的国际化

对于软件中的菜单栏、导航条、错误提示信息,状态信息等这些固定不变的文本信息,可以把它们写在一个properties文件中,并根据不同的国家编写不同的prop

erties文件。这一组properties文件称之为一个资源包.

在JavaAPI中提供了一个ResourceBundle 类用于描述一个资源包,并且 ResourceBundle类提供了相应的方法getBundle,这个方法可以根据来访者的国家地区

自动获取与之对应的资源文件予以显示.

ResourceBundle在查找资源文件时,首先找指定的,如果找不到找操作系统语言环境的,如果还找不到用默认的

     4.创建资源包和资源文件

一个资源包中的每个资源文件都必须拥有共同的basename基名。除了基名,每个资源文件的名称中还必须有标识其本地信息的附加部分。例如:一个资源包的基

是“resource”,则与中文、英文环境相对应的资源文件名则为: 

每个资源包都应有一个默认资源文件,这个文件不带有标识本地信息的附加部分。若ResourceBundle对象在资源包中找不到与用户匹配的资源文件,它将选择该

源包中与用户最相近的资源文件,如果再找不到,则使用默认资源文件.

      5.编程实现固定文本的国际化

/*
		 * ResourceBundle在查找资源文件时,首先找指定的,如果找不到找操作系统语言环境的,如果还找不到用默认的
		 */
		ResourceBundle bundle = ResourceBundle.getBundle("resource",Locale.FRANCE);
		String value = bundle.getString("username");
		System.out.println(value);
5.Locale对象

二、举例说明,代码如下

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  </head>
  <body>
  	<h1>java方式实现的页面国际化</h1><hr>
  	<%
  		Locale local = request.getLocale();
  		ResourceBundle bundle = ResourceBundle.getBundle("resource",local);
  	 %>
  	<form action="#">
  		<%=bundle.getString("username") %>:<input type="text"/>
  		<%=bundle.getString("password") %>:<input type="password"/>
  		<input type="submit" value="<%=bundle.getString("submit") %>"/>
  	</form>
  	
  
  	<h1>fmt标签方式实现的页面国际化</h1><hr>
  	<fmt:setBundle basename="resource" var="bundle" scope="page"/>
  	<form action="#">
  		<fmt:message bundle="${bundle}" key="username"/>:<input type="text"/>
  		<fmt:message bundle="${bundle}" key="password"/>:<input type="password"/>
  		<input type="submit" value="<fmt:message bundle="${bundle}" key="submit"/>"/>
  	</form>
  	
  </body>
</html>
上面分别采用了两种方式来实现资源国际化,第一种是采用了jsp页面嵌入java代码,第二种是使用fmt标签来实现。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jquery.i18n.properties是一个轻量级的jQuery国际化插件,用于在前端页面实现资源国际化。下面是一个基于jquery.i18n.properties实现前端页面的资源国际化的示例代码: 1. 引入依赖: ```html <script src="jquery.min.js"></script> <script src="jquery.i18n.properties.min.js"></script> ``` 2. 创建资源文件: 在项目的根目录下创建针对每种语言的资源文件,例如 `messages.properties`、`messages_zh.properties`、`messages_en.properties`,分别用于存储不同语言的资源信息。 messages.properties: ``` welcome_title=欢迎使用 welcome_message=你好,世界! ``` messages_zh.properties: ``` welcome_title=歡迎使用 welcome_message=你好,世界! ``` messages_en.properties: ``` welcome_title=Welcome welcome_message=Hello, world! ``` 3. 初始化插件: ```javascript $(function() { jQuery.i18n.properties({ name: 'messages', path: 'path/to/resources/', mode: 'both', language: 'zh', callback: function() { // 执行其他需要进行国际化的逻辑 $('#title').text($.i18n.prop('welcome_title')); $('#message').text($.i18n.prop('welcome_message')); } }); }); ``` 通过调用jQuery.i18n.properties来初始化该插件,其中name参数指定了资源文件的前缀名,path参数指定了资源文件的路径,mode参数设置为'both'以支持服务器端和客户端的资源文件加载方式,并通过language参数指定了应加载的语言版本。在回调函数中,可以通过$.i18n.prop方法获取指定资源国际化文本。 4. 在HTML中使用国际化资源: ```html <h1 id="title"></h1> <p id="message"></p> ``` 以上代码将根据不同的语言版本显示不同的欢迎标题和消息。 通过上述步骤,可以实现前端页面的资源国际化,根据不同的语言版本加载对应的资源文件,并将资源中定义的文本进行国际化显示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值