JS轉碼與解碼


escape 和 unescape

escape()不能直接用於URL編碼,它的真正作用是返回一個字符的Unicode編碼值

采用unicode字符集對指定的字符串除0-255以外進行編碼。所有的空格符、標點符號、特殊字符以及更多有聯系非ASCII字符都將被轉化成%xx格式的字符編碼(xx等於該字符在字符集表里面的編碼的16進制數字)。比如,空格符對應的編碼是%20。
escape不編碼字符有69個:*,+,-,.,/,@,_,0-9,a-z,A-Z。

escape()函數用於js對字符串進行編碼

encodeURI 和 decodeURI

把URI字符串采用UTF-8編碼格式轉化成escape各式的字符串。
encodeURI不編碼字符有82個:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z

encodeURI()用於整個url編碼

encodeURIComponent 和 decodeURIComponent

與encodeURI()的區別是,它用於對URL的組成部分進行個別編碼,而不用於對整個URL進行編碼。

因此,"; / ? : @ & = + $ , #",這些在encodeURI()中不被編碼的符號,在encodeURIComponent()中統統會被編碼。至於具體的編碼方法,兩者是一樣。把URI字符串采用UTF-8編碼格式轉化成escape格式的字符串。

encodeURIComponent() 用於參數的傳遞,參數包含特殊字符可能會造成間斷

總結

escape編碼字符串

簡單來說,escape是對字符串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。
編碼之后的效果是%XX或者%uXXXX這種形式。
其中 ASCII字母 數字 @*/+ 等字符不會被編碼,其余的都會。
最關鍵的是,當需要對URL編碼時,忘記這個方法,這個方法是針對字符串使用的,不適用於URL。

URL編碼encodeURI和encodeURIComponent

對URL編碼是常見的事,所以這兩個方法應該是實際中要特別注意的。它們都是編碼URL,唯一區別就是編碼的字符范圍,其中

encodeURI方法 不會對下列字符編碼  ASCII字母 數字 ~!@#$&*()=:/,;?+'
encodeURIComponent方法 不會對下列字符編碼  ASCII字母 數字 ~!*()'
所以encodeURIComponent比encodeURI編碼的范圍更大。
實際例子來說,encodeURIComponent會把 http:// 編碼成 http%3A%2F%2F 而encodeURI卻不會。
 
如果只是編碼字符串,不和URL有半毛錢關系,那么用escape。

如果你需要編碼整個URL,然后需要使用這個URL,那么用encodeURI。
比如
encodeURI("http://www.cnblogs.com/some other thing");

編碼結果:

http://www.cnblogs.com/some%20other%20thing

其中,空格被編碼成了%20。但是如果用了encodeURIComponent,那么結果變為

http%3A%2F%2Fwww.cnblogs.com%2Fseason-huang%2Fsome%20other%20thing

連 "/" 都被編碼了,整個URL已經沒法用了。

當需要編碼URL中的參數的時候,那么encodeURIComponent是最好方法

var param = "http://www.cnblogs.com/"; //param為參數
param = encodeURIComponent(param);
var url = "http://www.cnblogs.com?next=" + param;
console.log(url) //"http://www.cnblogs.com?next=http%3A%2F%2Fwww.cnblogs.com%2F"

參數中的 "/" 可以編碼,如果用encodeURI肯定要出問題,因為后面的/是需要編碼的。

參考:

https://www.cnblogs.com/lvmylife/p/7595036.html

https://www.cnblogs.com/moranhuishou/p/6209387.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM