js符號轉碼 JS轉碼與解碼

2021-10-13 04:44:48 字數 1917 閱讀 8657

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或者%u***x這種形式。

其中 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(" other thing");

編碼結果:

%20other%20thing

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

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

當需要編碼url中的引數的時候,那麼encodeuricomponent是最好方法

var param = ""; //param為引數

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

參考:

js符號轉碼 如何通過JS實現轉碼與解碼

易採站長站為您分析如何通過js實現轉碼與解碼,文中通過示例 介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下 escape 和 unescape escape 不能直接用於url編碼,它的真正作用是返回乙個字元的unicode編碼值。採用unicode字符集對指定的字...

JS對URL進行轉碼與解碼

用途 用於js對字串編碼 escape 用於整個url編碼 encodeurl 用於引數傳遞編碼 encodeuricomponent 詳解 1.escape 和 unescape escape 不能直接用於url編碼,它的真正作用是返回乙個字元的unicode編碼值。採用unicode字符集對指定...

js符號轉碼 在js中對中文和特殊字元轉碼

先貼一下js中關於轉碼的一點知識 js對文字進行編碼涉及3個函式 escape,encodeuri,encodeuricomponent,相應3個解碼函式 unescape,decodeuri,decodeuricomponent 1 傳遞引數時需要使用encodeuricomponent,這樣組合...