js中的escape的用法汇总
js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent
1  传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。                           
例如:<script language="javascript">document.write('<a href="passport.baidu/?logout&aid=7& u='+encodeURIComponent("cang.baidu/bruce42")+'">退出</a& gt;');</script>
2  进行url跳转时可以整体使用encodeURI
例如:Location.href=encodeURI("cang.baidu/do/s?word=百度&ct=21");
3  js使用数据时可以使用escape
[Huoho.Com编辑]
例如:搜藏中history纪录。
4  escape0-255以外的unicode值进行编码时输出%u****格式,其它情况下escapeencodeURIencodeURIComponent编码结果相同。
  最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)
escape不编码字符有69个:*+-./@_0-9a-zA-Z
encodeURI不编码字符有82个:!#$&'()*+,-./:;=?@_~0-9a-zA-Z
encodeURIComponent不编码字符有71个:! '()*-._~0-9a-zA-Z
    escape(str) 方法,它用于转义不能用明文正确发送的任何字符。比如,电话号码中的空格将被转换成字符 %20,从而能够在 URL 中传递这些字符
如果需要发送安全信息或 XML,可能要考虑使用 send() 发送内容(本系列的后续文章中将讨论安全数据和 XML 消息)。如果不需要通过script在html中的用法 send() 传递数据,则只要传递 null 作为该方法的参数即可。
js中的escape可以加密数据

我在用opener给前以页面传值的时候,遇到了数据被过滤的事情,好像是空格还是什么符号

被过滤了,想到了escape,好了,我就加密一下,传过去再解密

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。