当前位置:首页 > 芯闻号 > 充电吧
[导读]并行处理系统的国际化主要包括前端的国际化、后端的国际化和算法的国际化。前端的国际化包括css、js和html文件的国际化,后端的国际化包括jsp、java代码的国际化。          jsp的国际

并行处理系统的国际化主要包括前端的国际化、后端的国际化和算法的国际化。前端的国际化包括css、js和html文件的国际化,后端的国际化包括jsp、java代码的国际化。


          jsp的国际化方式的方式是采用国际化标签库的方式。具体是在jsp页面添加如下代码:


  // 导入fmt库// 设置为英文,若设置为中文则是zh_CN//确保加载的是webWebContentWEB-INFclassesjsp_en_US.properties文件" cdata_tag="script" _ue_custom_node_="true">// 确保加载



        html页面的国际化(含Javascript的国际化)采用读取Properties文件的方式,具体参考使用jQuery.i18n.properties实现 Web 前端的国际化的实现方式。和文中不一样的是,不再是用户手动选择语言版本,而是改用js读取语言版本配置文件来决定读取哪个版本资源文件。代码大致如下:


var bLoad= false;
function getRootPath() {
    var pathName = window.location.pathname.substring(1);
    var webName = pathName == '' ? '' : pathName.substring(0, pathName.indexOf('/'));
    return window.location.protocol + '//' + window.location.host + '/'+ webName;
    }  

function GetValueByKey(key){
	if(!bLoad)
	{
		loadProperties();
		bLoad=true;
	}
	var value = $.i18n.prop(key);
	return value;
};

function loadProperties(){
	var JsSrc = (navigator.language || navigator.browserLanguage).toLowerCase();
	if(JsSrc.indexOf('zh')>=0)
	{
		JsSrc = 'js_zh_CN';
	}
	else if(JsSrc.indexOf('en')>=0)
	{
	    JsSrc = 'js_en_US';
	}
	else
	{
		JsSrc = 'js_zh_CN'; 	
	}
	
	var i18npath = getRootPath()+ "/resources/js/"
	jQuery.i18n.properties({//加载资浏览器语言对应的资源文件
		name:JsSrc, //资源文件名称
		path: i18npath,                      //'resources/js/', //资源文件路径
		mode:'map', //用Map的方式使用资源文件中的值
		callback: function() {//加载成功后设置显示内容

		}
	});
};


       其它的js可以这样调用:



document.write("");  // 这句放在最前面
var key = “user”;
var value =  GetValueByKey(key);


       


      java部分的国际化,采用读取语言配置文件,语言配置文件大致如下:


 


然后增加一个Java读取这个配置文件的类:

// 读取语言配置文件的语言配置类
public class LangConfInit {
	public static String language = null;
	public static ResourceBundle rb=null;
	public LangConfInit(){
		if(null == language && null == rb){
			language = ConfigUtil.getProperty("LangConf","Lang");
			rb = ResourceBundle.getBundle("message_"+language);
		}
	}
	
	public String GetValue(String key)
	{
		try {
			String keyValue = new String(rb.getString(key).getBytes("ISO-8859-1"), "utf-8");
			return  keyValue;
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		}  
		return null;
	}


调用代码如下:


public LangConfInit lang =new LangConfInit();
String vaule = lang.GetValue("user");



     css的国际化另外写文章进行论述。

 

参考文献:

1. 用jQuery.i18n.properties实现 Web 前端的国际化
2. 使用JSP的fmt标签实现国际化支持
3.JavaWeb 后端

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭