参考:https://www.cnblogs.com/zhaojunhao/p/9638775.htmlhttps://www.cnblogs.com/z-one/p/6542955.html

escape 和 unescape

escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。
采用unicode字符集对指定的字符串除0-255以外进行编码。所有的空格符、标点符号、特殊字符以及更多有联系非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。
escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z。
escape()函数用于js对字符串进行编码,不常用。

  1. 编码:escape('http://www.baidu.com?name=zhang@xiao@jie&order=1')
  2. 结果:"http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1"
  3. 编码:escape('张')
  4. 结果:"%u5F20"
  5. 解码:unescape("http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1")
  6. 结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"
  7. 解码:unescape("%u5F20")
  8. 结果:"张"

encodeURI 和 decodeURI

把URI字符串采用UTF-8编码格式转化成escape各式的字符串。
encodeURI不编码字符有82个:!,#,$,&,’,(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURI()用于整个url编码

  1. 编码:encodeURI('http://www.baidu.com?name=zhang@xiao@jie&order=1')
  2. 结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"
  3. 解码:decodeURI("http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1")
  4. 结果:"http%3A//www.baidu.com%3Fname%3Dzhang@xiao@jie%26order%3D1"

encodeURIComponent 和 decodeURIComponent

与encodeURI()的区别是,它用于对URL的组成部分进行个别编码,而不用于对整个URL进行编码。

因此,”; / ? : @ & = + $ , #”,这些在encodeURI()中不被编码的符号,在encodeURIComponent()中统统会被编码。至于具体的编码方法,两者是一样。把URI字符串采用UTF-8编码格式转化成escape格式的字符串。

encodeURIComponent() 用于参数的传递,参数包含特殊字符可能会造成间断。

  1. 编码:encodeURIComponent('http://www.baidu.com?name=zhang@xiao@jie&order=1')
  2. 结果:"http%3A%2F%2Fwww.baidu.com%3Fname%3Dzhang%40xiao%40jie%26order%3D1"
  3. 解码:decodeURIComponent("http%3A%2F%2Fwww.baidu.com%3Fname%3Dzhang%40xiao%40jie%26order%3D1")
  4. 结果:"http://www.baidu.com?name=zhang@xiao@jie&order=1"

总结

escape()不能直接用于URL编码,它的真正作用是返回一个字符的Unicode编码值。比如”春节”的返回结果是%u6625%u8282,,escape()不对”+”编码
主要用于汉字编码,现在已经不提倡使用。

encodeURI()是Javascript中真正用来对URL编码的函数。
编码整个url地址,但对特殊含义的符号”; / ? : @ & = + $ , #”,也不进行编码。对应的解码函数是:decodeURI()。

encodeURIComponent()
能编码”; / ? : @ & = + $ , #”这些特殊字符。对应的解码函数是decodeURIComponent()。
想要传递带&符号的网址,所以用encodeURIComponent()