`
星海孤舟
  • 浏览: 68962 次
  • 性别: Icon_minigender_1
  • 来自: 哈尔滨
社区版块
存档分类
最新评论

escape,encodeURI,encodeURIComponent

阅读更多

(转载一部分,综合一部分)

网上查到的全都是escape,和需要的编码不是一回事,好不容易找到的结果 保存下来以备以后使用

js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent

1、   传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。                            

例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a>');</script>

2、   进行url跳转时可以整体使用encodeURI

例如:Location.href="/encodeURI"("http://cang.baidu.com/do/s?word=百度&ct=21");

3、   js使用数据时可以使用escape

例如:搜藏中history纪录。

4、   escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。


最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)

escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z

encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z (url的特殊字符不会编码,不会破坏url结构)

encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z(url的特殊字符也会被编码)

示例:

1 escape()

escape("http://www.w3school.com.cn") 

http%3A//www.w3school.com.cn

escape("?!=()#%&")

%3F%21%3D%28%29%23%25%262 

2 encodeURI()

encodeURI("http://www.w3school.com.cn")

http://www.w3school.com.cn

encodeURI("http://www.w3school.com.cn/My first/")

http://www.w3school.com.cn/My%20first/

encodeURI(",/?:@&=+$#")

,/?:@&=+$#

对整个URL进行编码,而URL的特定标识符不会被转码。

encodeURIComponent()

encodeURIComponent("http://www.w3school.com.cn")

http%3A%2F%2Fwww.w3school.com.cn

encodeURIComponent("http://www.w3school.com.cn/p 1/")
http%3A%2F%2Fwww.w3school.com.cn%2Fp%201%2F

encodeURIComponent(",/?:@&=+$#")
%2C%2F%3F%3A%40%26%3D%2B%24%23


2<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a>');

</script>

<!--EndFragment-->
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics