编码就是把能看的懂得字符转换成一些奇奇怪怪的二进制字节码文件
解码就是把哪些看不懂的二进制字节码转换成能看的懂得字符
为什么要进行编码
在URI的最初设计时,希望能通过书面转录,比如写在餐巾纸上告诉另外一人,因此URI的构成字符必须是可写的ASCII字符。在这些可书写的字符里,由于一些字符在不同操作系统的编码有不同的解析,被包含在“不安全字符”之中,要格外注意。
废话少说,我们先来准备一个字符串
var str = 'http://www.baidu.co m/+do/s?word=百度&ct=21';
escape() 和 unescape()
var a = escape(str);
console.log(a)
结果:http%3A//www.baidu.com/do/s%3Fword%3D%u767E%u5EA6%26ct%3D21
返回一个以编码string的副本。 其中的某些字符被替换成了16进制的转义序列
该方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。其他所有的字符都会被转义序列替换。
只能被unescape()所解码,使用decodeURI()和decodeURIComponent()解码时会直接报错。
js使用数据时可以使用escape。
var b = unescape(a);
console.log(b)
结果:http://www.baidu.com/do/s?word=百度&ct=21
只能解码escape()所转的编码,解码encodeURI()和encodeURIComponent()转的URI时会把文字转为(奇奇怪怪的乱码)特殊编码。
encodeURI 和 encodeURIComponent()
var c = encodeURI(str);
console.log(c)
结果:http://www.baidu.com/do/sword=%E7%99%BE%E5%BA%A6&ct=21
返回一个URLstring的副本,其中的某些字符将被16进制的转义序列进行替换。
该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。该方法的目的是对 URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的:;/?:@&=+$,#
var d = encodeURIComponent(str);
console.log(d)
结果:http%3A%2F%2Fwww.baidu.com%2Fdo%2Fs%3Fword%3D%E7%99%BE%E5%BA%A6%26ct%3D21
返回一个URLstring的副本,其中的某些字符将被16进制的转义序列进行替换。
该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ' ( ) 。其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。
encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。
decodeURI
进行url跳转时可以整体使用encodeURI
对于encodeURIComponent()转义替换的分隔 URI 组件的符号无法进行解码。
var e = decodeURI(c);
console.log(e)
http://www.baidu.com/do/s?word=百度&ct=21
var f = decodeURI(d);
console.log(f)
结果:http%3A%2F%2Fwww.baidu.co m%2F%2Bdo%2Fs%3Fword%3D百度%26ct%3D21%23name%3D"la"
decodeURIComponent
传递参数时需要使用encodeURIComponent,这样组合的url才不会被#等特殊字符截断。
var y = decodeURIComponent(d);
console.log(y)
结果:http://www.baidu.com/do/s?word=百度&ct=21
var z = decodeURIComponent(c);
console.log(z)
结果:http://www.baidu.com/do/s?word=百度&ct=21
escape()是JavaScript 1.0 时的
encodeURI() 和 encodeURIComponent()是 JavaScript 1.5 的
通过对三个函数的分析,我们可以知道:escape()除了 ASCII 字母、数字和特定的符号外,对传进来的字符串全部进行转义编码,因此如果想对URL编码,最好不要使用此方法。而encodeURI() 用于编码整个URI,因为URI中的合法字符都不会被编码转换。ncodeURIComponent方法在编码单个URIComponent(指请求参数)应当是最常用的,它可以讲参数中的中文、特殊字符进行转义,而不会影响整个URL。
// 参考一下就算了
escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下escape,encodeURI,encodeURIComponent编码结果相同。最多使用的应为encodeURIComponent,它是将中文、韩文等特殊字符转换成utf-8格式的url编码,所以如果给后台传递参数需要使用encodeURIComponent时需要后台解码对utf-8支持(form中的编码方式和当前页面编码方式相同)