谈谈encodeURI和encodeURIComponent以及escape的区别与应用
首先,我们都知道这三个东西都是用来编码的先来说encodeURI()和encodeURIComponent(),这两个是在转换url时候用来编码解码用的。
有编码就会有解码,解码就是decodeURI()和decodeURIComponent(),他们的用法很简单,在参数中带入要转码的文字就可实现目的
如:
encodeURI("我是要编码的文字")
decodeURI("我是要解码的文字")
encodeURIComponent("我是要编码的文字")
decodeURIComponent("我是要解码的文字")
而encodeURI()和encodeURIComponent()的区别其实并不大
主要区别在于:
encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURIComponent不编码字符有71个:!,',(,),*,-,.,_,~,0-9,a-z,A-Z
encodeURI主要用于直接赋值给地址栏时候:
location.href=encodeURI("http://www.cnblogs.com/Tezml/");
而encodeURIComponent主要用于url的query参数:
location.href="http://www.cnblogs.com/Tezml/test.php?a="+encodeURIComponent("我就是我");
而escape,相比于上面那两个,就有所不同了
escape()是编码,unescape()是解码;
escape方法
对String对象编码以便它们能在所有计算机上可读,
escape(charString)
必选项charstring参数是要编码的任意String对象或文字。
说明
escape方法返回一个包含了charstring内容的字符串值(Unicode格式)。所有空格、标点、重音符号以及其他非ASCII字符都用%xx编码代替,
其中xx等于表示该字符的十六进制数。例如,空格返回的是"%20"。
字符值大于255的以%uxxxx格式存储。
escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z
注意 escape方法不能够用来对统一资源标示码(URI)进行编码。对其编码应使用encodeURI和encodeURIComponent方法。
最后上一段关于编码解码的demo
<!DOCTYPEhtml> <html> <head> <title>Tezml_编码解码测试</title> <metacharset="utf-8"> <metaname="author"content="Tezml"/> <metaname="copyright"content="Tezml"/> <metaname="description"content="Tezml"/> <scripttype="text/javascript"src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script> </head> <body> <divid="wz1"></div> <divid="wz2"></div> <divid="wz3"></div> <divid="wz4"></div> <divid="wz5"></div> <divid="wz6"></div> <divid="wz7"></div> <divid="wz8"></div> <divid="wz9"></div> <divid="wz10"></div> <divid="wz11"></div> <divid="wz12"></div> </body> <scripttype="text/javascript"> varchinese="请叫我中文" varenglish="placetallmeenglash" varMonster=":#&$/@" $("#wz1").html(encodeURI(chinese))//编码%E8%AF%B7%E5%8F%AB%E6%88%91%E4%B8%AD%E6%96%87 $("#wz2").html(decodeURI(chinese))//解码请叫我中文 $("#wz3").html(encodeURI(english))//编码place%20tall%20me%20englash $("#wz4").html(decodeURI(english))//解码placetallmeenglash $("#wz5").html(encodeURIComponent(Monster))//编码%3A%23%26%24%2F%40 $("#wz6").html(encodeURI(Monster))//编码:#&$/@ $("#wz7").html(escape(chinese))//编码%u8BF7%u53EB%u6211%u4E2D%u6587 $("#wz8").html(escape(english))//编码place%20tall%20me%20englash $("#wz9").html(escape(Monster))//编码%3A%23%26%24/@ $("#wz10").html(unescape(chinese))//编码请叫我中文 $("#wz11").html(unescape(english))//编码placetallmeenglash $("#wz12").html(unescape(Monster))//编码:#&$/@ </script> </html>
总结
escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。比如"春节"的返回结果是%u6625%u8282,,escape()不对"+"编码主要用于汉字编码,现在已经不提倡使用。
encodeURI()是Javascript中真正用来对URL编码的函数。编码整个url地址,但对特殊含义的符号";/?:@&=+$,#",也不进行编码。对应的解码函数是:decodeURI()。
encodeURIComponent()能编码";/?:@&=+$,#"这些特殊字符。对应的解码函数是decodeURIComponent()。
假如要传递带&符号的网址,所以用encodeURIComponent()