如何通過JS實現(xiàn)轉(zhuǎn)碼與解碼
這篇文章主要介紹了如何通過JS實現(xiàn)轉(zhuǎn)碼與解碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
escape 和 unescape
escape()不能直接用于URL編碼,它的真正作用是返回一個字符的Unicode編碼值。
采用unicode字符集對指定的字符串除0-255以外進行編碼。所有的空格符、標點符號、特殊字符以及更多有聯(lián)系非ASCII字符都將被轉(zhuǎn)化成%xx格式的字符編碼(xx等于該字符在字符集表里面的編碼的16進制數(shù)字)。比如,空格符對應(yīng)的編碼是%20。
escape不編碼字符有69個:*,+,-,.,/,@,_,0-9,a-z,A-Z。
escape()函數(shù)用于js對字符串進行編碼。
encodeURI 和 decodeURI
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape各式的字符串。
encodeURI不編碼字符有82個:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURI()用于整個url編碼
encodeURIComponent 和 decodeURIComponent
與encodeURI()的區(qū)別是,它用于對URL的組成部分進行個別編碼,而不用于對整個URL進行編碼。
因此,"; / ? : @ & = + $ , #",這些在encodeURI()中不被編碼的符號,在encodeURIComponent()中統(tǒng)統(tǒng)會被編碼。至于具體的編碼方法,兩者是一樣。把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。
encodeURIComponent() 用于參數(shù)的傳遞,參數(shù)包含特殊字符可能會造成間斷。
總結(jié)
escape編碼字符串
簡單來說,escape是對字符串(string)進行編碼(而另外兩種是對URL),作用是讓它們在所有電腦上可讀。
編碼之后的效果是%XX或者%uXXXX這種形式。
其中 ASCII字母 數(shù)字 @*/+ 等字符不會被編碼,其余的都會。
最關(guān)鍵的是,當需要對URL編碼時,忘記這個方法,這個方法是針對字符串使用的,不適用于URL。
URL編碼encodeURI和encodeURIComponent
對URL編碼是常見的事,所以這兩個方法應(yīng)該是實際中要特別注意的。它們都是編碼URL,唯一區(qū)別就是編碼的字符范圍,其中
encodeURI方法不會對下列字符編碼 ASCII字母 數(shù)字 ~!@#$&*()=:/,;?+'
encodeURIComponent方法不會對下列字符編碼 ASCII字母 數(shù)字 ~!*()'
所以encodeURIComponent比encodeURI編碼的范圍更大。
實際例子來說,encodeURIComponent會把 http:// 編碼成 http%3A%2F%2F 而encodeURI卻不會。
如果只是編碼字符串,不和URL有半毛錢關(guān)系,那么用escape。
如果你需要編碼整個URL,然后需要使用這個URL,那么用encodeURI。
比如
encodeURI(http://www.cnblogs.com/some other thing);
編碼結(jié)果:
http://www.cnblogs.com/some%20other%20thing
其中,空格被編碼成了%20。但是如果用了encodeURIComponent,那么結(jié)果變?yōu)?/p>
http%3A%2F%2Fwww.cnblogs.com%2Fseason-huang%2Fsome%20other%20thing
連 "/" 都被編碼了,整個URL已經(jīng)沒法用了。
當需要編碼URL中的參數(shù)的時候,那么encodeURIComponent是最好方法
var param = "http://www.cnblogs.com/"; //param為參數(shù) 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
參數(shù)中的 "/" 可以編碼,如果用encodeURI肯定要出問題,因為后面的/是需要編碼的。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- JS字符串與二進制的相互轉(zhuǎn)化實例代碼詳解
- js實現(xiàn)unicode碼字符串與utf8字節(jié)數(shù)據(jù)互轉(zhuǎn)詳解
- 解決Pandas to_json()中文亂碼,轉(zhuǎn)化為json數(shù)組的問題
- 詳解json string轉(zhuǎn)換為java bean及實例代碼
- JS實現(xiàn)漢字與Unicode碼相互轉(zhuǎn)換的方法詳解
- javascript使用btoa和atob來進行Base64轉(zhuǎn)碼和解碼
- js 轉(zhuǎn)義字符及URI編碼詳解
- js中unicode轉(zhuǎn)碼方法詳解
- js unicode 編碼解析關(guān)于數(shù)據(jù)轉(zhuǎn)換為中文的兩種方法
相關(guān)文章
如何實現(xiàn)textarea里的不同文本顯示不同顏色
如何實現(xiàn)textarea里的不同文本顯示不同顏色呢?控制textarea的style設(shè)置Textarea以及把文本放到標記里都不會起作用,下面有個不錯的解決方法,感興趣的朋友可以了解下2014-01-01

JavaScript實現(xiàn)通過鍵盤彈鋼琴的效果實例代碼

JavaScript實現(xiàn)shuffle數(shù)組洗牌操作示例

JS生態(tài)系統(tǒng)加速一次一庫PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索

屏蔽網(wǎng)頁右鍵復(fù)制和ctrl+c復(fù)制的js代碼

JS實現(xiàn)網(wǎng)頁上隨機產(chǎn)生超鏈接地址的方法