关于 escape、encodeURI、encodeURIComponent-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

关于 escape、encodeURI、encodeURIComponent

简介:

参考资料:http://hi.baidu.com/flondon/item/983b3af35b83fa13ce9f3291

       http://www.w3school.com.cn/js/jsref_escape.asp

 

 

escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串。解码:unescape()

encodeURI() 函数可把字符串作为 URI 进行编码。 解码:decodeURI()

encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。解码:decodeURIComponent()

 

共同点:

这三个函数均采用unicode字符集。

 

不同点:

escape是将字符的unicode编码转化为16进制序列(转义序列,转义序列(escape sequences)),其不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z。

encodeURI是将字符的unicode编码通过UTF-8来表示,其不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z。

encodeURIComponent也是将字符的unicode编码通过UTF-8来表示,其与encodeURI的唯一区别就是它们不编码的字符有所差别,encodeURIComponent不编码的字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z。

 

使用场景

1. 传递参数时(GET方法)需要使用encodeURIComponent,这样组合的URL才不会被#、?、&等特殊字符所干扰。

2. 对URL(URL是一种URI)进行整体编码时使用encodeURI,这样就可以确保URL中的特殊含义字符(#、?、&、etc.)不被编码。

3. ECMAScript v3中反对对escape()的使用,并建议用encodeURI和encodeURIComponent代替,不过escape()依然被广泛的用于cookie的编码,因为escape()恰好编码了cookie中的非法字符并且对路径中常出现的“/”不进行编码。

本文转自挨踢前端博客园博客,原文链接http://www.cnblogs.com/duanhuajian/p/3499697.html如需转载请自行联系原作者


@挨踢前端

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章
最新文章
相关文章
展开