`
pouyang
  • 浏览: 312447 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JavaScript语言精粹 字符串(example:js变量作为URL参数乱码)

阅读更多

  字符串可以被包含在单引号或双引号中,它可能包含0个或多个字符\(反斜线符号)是转义字符
  JavaScript在被创建的时候,Unicode是一个16位的字符集,所以JavaScript中的所有字符都是16位的.
  JavaScript没有字符类型,要表示一个字符,只须创建仅包含一个字符的字符串即可


alert("A" == "\u0041");//true
alert("seven".length); // 5
"o"+"y"+"p" == "oyp";//true;
"oyp".toUpperCase() == 'CAT';


字符串是不可变的,一旦字符串被创建,就永远无法改变它,跟java一样,所以语言都是相通的



现在流行的异步提交,丰富多彩的互联网,现在不仅程序员享受着这种异步交互带来的成就感,客户也很期待也很享受Ajax的强大的交互功能,异步提交难免会出现js变量(中文)作为URL参数,js变量作为URL参数传到后台会出现中文乱码情况,(Jquery form动态提交不会出现乱码问题),异步请求过去会得到,以下是解决方法


//前台
var accountCN ="中文";
var account = encodeURI(encodeURI(accountCN));// 关键所在
var updateURL = "http://localhost:7001/ouyangping/demo.do?account="account
function updateRow(updateURL) {
	$.ajax( {
		type : "POST",
		url :updateURL,
		cache : false,
		dataType: "json",
		success : function updateSuceess(data) {
		
			
			if (data.state == '1') {
				alert('修改成功!');
			} else {	
				alert('修改失败!');
			}
		}
	});
}


//后台 控制层

String	account = java.net.URLDecoder.decode(iRequest.getParameter("account"),"utf-8");//关键所在
JSONObject json = new JSONObject();
json.clear();
iResponse.setHeader("X-JSON", json.toString());
iResponse.setCharacterEncoding("UTF-8");
iResponse.setHeader("Cache-Control", "no-cache,must-revalidate");// 清楚缓存
iResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
iResponse.setDateHeader("Expires", 0); // prevents caching at the
//更新是否成功
//int state = userManagerService.modUserByYui(userManagerDTO);
int state = userManagerService.modUserByYui(userManagerDTOJS);
json.put("state",state);
try {
	iResponse.getWriter().print(json.toString());
} catch (IOException e) {
	e.printStackTrace();
}
return null;

------------------------

  有了两个关键所在,就可以处理中文乱码问题了.但是很多地方都要处理,所以也要重构下
  这也带来了问题,如果URL后面的参数过多那么会导致URL非常长,曾经考虑过把所有参数封装成一个变量传递过去,这种方法可行是可行,但是解决不了中文乱码的问题,以下附上这种方法.



//这种把对象o传递过去,o里的内容是json格式。
Object o = new Object()
o.user = document.getElementById("user");
o.password = document.getElementById("password");




//以Json格式获取页面上的查询条件,且这些参数的name要一致
function getJsonParameters(page) {
	$('input:text').each(function(){ 
    	this.value = jQuery.trim(this.value);
    	}
    ); 
	var parameters = document.getElementsByName('form1');
	var parameter = "{";
	for (var i = 0 ; i < parameters.length; i++ ) {
		if (parameters[i].value != null && parameters[i].value != '') {
			parameter += parameters[i].id +":'"+parameters[i].value+"',";
		}
	}
	if (''+page != 'undefined'){
		parameter +='page'+":'"+page+"',";
	}
	parameter += "}";
	return parameter;
}

o 或者 parameter 传递过去,这种格式的在后台这样处理:


	
// 页面参数转化为Bean
String parameter = iRequest.getParameter("parameter");
			JSONObject jsonObject = JSONObject.fromObject(parameter);
			UserManagerDTO user = (UserManagerDTO) JSONObject.toBean(
					jsonObject, UserManagerDTO.class);
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics