JavaScript encodeURI 和encodeURIComponent
encodeURI和encodeURIComponet函数都是javascript中用来对URI进行编码,将相关参数转换成UTF-8编码格式的数据。URI在进行定位跳转时,参数里面的中文、日文等非ASCII编码都会进行编码转换。
这两个函数功能上面比较接近,但是有一些区别。
encodeURI:不会进行编码的字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURIComponent:不会进行编码的字符有71个:!,',(,),*,-,.,_,~,0-9,a-z,A-Z
问题:
ajax.get(url+'?k1'=v1+'&k2'=v2+'&k3'=v3,...);
由于URL只进行了encodeURI编码,所以想提交的参数有searchWord=a+b时,变成了ab。
解决办法:
ajax.post(url,params,....)
其中params是对象。
原因:如果参数是对象或数组时,组件库已经帮你进行encodeURIComponent了。而如果你仅仅是字符串,组件库什么也没做,所以到后端时就把特殊字符给过滤了。
encodeURI()用法
该方法不会对ASCII字母和数字进行编码,也不会对这些ASCII标点符号进行编码:-_.!~*'()。
该方法的目的是对URI进行完整的编码,因此对以下在URI中具有特殊含义的ASCII标点符号,encodeURI()函数是不会进行转义的:;/?:@&=+$,#
提示:如果URI组件中含有分隔符,比如?和#,则应当使用encodeURIComponent()方法分别对各组件进行编码。
例子:
document.write(encodeURI("http://www.w3school.com.cn")+"<br/>") document.write(encodeURI("http://www.w3school.com.cn/Myfirst/")) document.write(encodeURI(",/?:@&=+$#")) //批注:只转换域名后面的部分,并且对,/?:@&=+$#不处理。 //http://www.w3school.com.cn //http://www.w3school.com.cn/My%20first/ //,/?:@&=+$#
decodeURI()函数可对encodeURI()函数编码过的URI进行解码。
encodeURIComponent()用法
该方法不会对ASCII字母和数字进行编码,也不会对这些ASCII标点符号进行编码:-_.!~*'()。
其他字符(比如:;/?:@&=+$,#这些用于分隔URI组件的标点符号),都是由一个或多个十六进制的转义序列替换的。
提示:请注意encodeURIComponent()函数与encodeURI()函数的区别之处,前者假定它的参数是URI的一部分(比如协议、主机名、路径或查询字符串)。因此encodeURIComponent()函数将转义用于分隔URI各个部分的标点符号。
例子:
document.write(encodeURIComponent("http://www.w3school.com.cn")) document.write(encodeURIComponent("http://www.w3school.com.cn/p1/")) document.write(encodeURIComponent(",/?:@&=+$#")) //对比 //http%3A%2F%2Fwww.w3school.com.cn //http%3A%2F%2Fwww.w3school.com.cn%2Fp%201%2F //%2C%2F%3F%3A%40%26%3D%2B%24%23
decodeURIComponent()函数可对encodeURIComponent()函数编码的URI进行解码。