知识,永远没有准备完备的时候,可以边做边捡。
做事,永远没有万事具备的时候,可以边做边学。
这样,经验也有了价值。时间价值。
今天又碰到了这个细节问题。虽然知道这几个函数可以解决,但用哪个,怎么用,何时用,还得搞清楚。
js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent
异同点总结:
escape() 方法:
采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都将被转化成%xx格式的字符编码(xx等于该字符在字符集表里面的编码的16进制数字)。比如,空格符对应的编码是%20。unescape方法与此相反。
不会被此方法编码的字符: @ * / +
提示:可以使用unescape() 对 escape() 编码的字符串进行解码。
注:ECMAScript v3 反对使用该方法,应用使用decodeURI() 和 decodeURIComponent()替代它。
encodeURI() 方法:
把URI字符串采用UTF-8编码格式转化成escape格式的字符串。
不会被此方法编码的字符:! @ # $& * ( ) = : / ; ? + '
(可以看出上面标注的符号都是链接里使用的特殊分隔符)
提示:可以使用decodeXXX进行解码。
encodeURIComponent() 方法:
把URI字符串采用UTF-8编码格式转化成escape格式的字符串。与encodeURI()相比,这个方法将对更多的字符进行编码,比如 / 等字符。所以如果字符串里面包含了URI的几个部分的话,不能用这个方法来进行编码,否则 / 字符被编码之后URL将显示错误。不会被此方法编码的字符:! * ( )
提示:可以使用decodeXXX进行解码。
对于中文字符串来说,如果不希望把字符串编码格式转化成UTF-8格式的(比如原页面和目标页面的charset是一致的时候),只需要使用escape。如果你的页面是GB2312或者其他的编码,而接受参数的页面是UTF-8编码的,就要采用encodeURI或者encodeURIComponent。
另外,encodeURI/encodeURIComponent是在javascript1.5之后引进的,escape则在javascript1.0版本就有。
小结:
上面讲了这么多,我是晕了,得总结个方法。而最好的方法就是理解,用理解其原理和实质,来解放大脑。
#编码不同
escape 是iso-latin编码
encodeXXX,是utf-8编码
也就是说:escape对0-255以外的unicode值进行编码时输出%u****格式,其它情况下 escape,encodeURI,encodeURIComponent编码结果相同
#编码结果格式相同
从上面的分析可以看出,其最终的结果都是转化为escape格式的字符串
#编码的对象不同
这3者都不对ascii字符和数字编码(要是编码就属于吃饱了撑着)
escape不编码字符有69个:*,+,-,.,/,@,_
encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~
encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~
从上面可以看出:
escape不编码的字符属于js运算特殊字符和命名规范的特殊字符,编码的字符数最多
encodeURI在escape上退了一步,不对URI本身的特殊字符编码,也就是说一个URI经过此编码,仍然可用
encodeURIComponent在encodeURI上进了一步,对URI本身的特殊字符也编码
在精简一点来说:
对encodeXXX,从命名上就知道,其就是用来对URI编码的,前者使得编码后的URI仍然可用,后者不行;
对escape,从命名就知道,其目的在于转义js代码,目的不在于URI编码,所以需要URI编码的就别用了;
如果还不理解,就再精简成一句话吧:
实际工作中,80%以上的场景用encodeURIComponent,偶尔会需要encodeURI,基本不会用到escapse。
从设计的角度来理解:
escape则在javascript1.0版本就有;
encodeURI/encodeURIComponent是在javascript1.5之后引进的;
很明显,这就是语言和方法的发展和补丁,太像我们平时的接口升级了。
发展历史推测:
最开始的1.0版本,就只有对js代码转义的需求,互联网和URI还处于“原始”社会。
随着network的发展,对URI编码有了需求,就加了encodeURI方法,可见其目的啊!
但上面的方法有漏洞,比如某个参数比如name=值,这个值就是URI的特殊字符。此时encodeURIComponent诞生了,其就是个补丁。
有了上面的总结,应用场景,应该了然于胸了。
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纪录。
参考:
http://shijian0306.iteye.com/blog/241264
http://blog.csdn.net/wxwzy738/article/details/7710288
http://hi.baidu.com/meback/item/a1fa5343f5f7ecab60d7b97d
http://www.dewen.org/q/238
pp
pp
==
相关推荐
在JavaScript中,`escape()`, `encodeURI()`, 和 `encodeURIComponent()` 是三个常见的字符串编码函数,它们各自有独特的用途和特点。理解它们的区别对于编写健壮的JavaScript代码至关重要。 首先,`escape()` 函数...
本文将详细介绍 `escape()`、`encodeURI()` 和 `encodeURIComponent()` 这三个函数的区别及其应用场景。 #### 1. `escape()` 函数 `escape()` 是一个用于编码 URL 字符串的方法,它会将非 ASCII 字符转换为 `%nn` ...
总结来说,理解并正确使用`escape`、`encodeURI`和`encodeURIComponent`是JavaScript开发中的重要技能,它们有助于确保数据在网络中的安全传输和正确解析。在处理URL、查询参数或其他需要编码的数据时,要根据具体...
在JavaScript中,`encodeURI()`、`encodeURIComponent()`和`escape()`是三个用于字符串编码的函数,它们的主要目的是确保特殊字符在传输过程中不会引起错误。理解它们之间的差异对于编写正确处理URL和数据的...
本文将详细介绍`escape()`、`encodeURI()`和`encodeURIComponent()`这三个函数,并解释它们的区别和使用场景。 首先,`escape()`方法是JavaScript最早提供的一个编码函数,它基于ISO Latin字符集对字符串进行编码。...
本文将详细介绍`escape()`, `encodeURI()`, `encodeURIComponent()`这三个函数的功能、使用场景以及它们之间的区别。 #### 一、`escape()`函数 `escape()`函数是JavaScript中较早出现的一种URL编码方式。它会将...
在JavaScript中,`escape()`, `encodeURI()`, 和 `encodeURIComponent()` 是三个常见的字符串编码函数,它们用于处理和转换字符串中的特殊字符。虽然它们都与字符串编码有关,但各自的作用和适用场景有所不同。 ...
本文主要关注三个与URL编码相关的函数:`escape`、`encodeURI`和`encodeURIComponent`。这些函数各有其特定的用途,理解它们的区别至关重要。 首先,我们来看`escape`函数。`escape`并不专门用于URL编码,它实际上...
JavaScript中的字符串编码函数主要包括`escape()`、`encodeURI()`和`encodeURIComponent()`,它们的作用是对字符串进行编码处理,以便在网络中安全地传输数据。这三种函数都有对应的解码函数:`unescape()`、`...
JavaScript中有三个可以对字符串编码的函数,分别是: escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape, decodeURI, decodeURIComponent 。 下面简单介绍一下它们的区别: 1 escape()函数 定义和...
encodeURI和encodeURIComponet函数都是javascript中用来对URI进行编码,将相关参数转换成UTF-8编码格式的数据。URI在进行定位跳转时,参数里面的中文、日文等非ASCII编码都会进行编码转换
escape(), encodeURI()和encodeURIComponent()是在Javascript中用于编码字符串的三个常用的方法,而他们之间的异同却困扰了很多的Javascript初学者,这篇文章详细的给大家介绍了js中编码函数:escape,encodeURI与...