javascript中存在幾種對URL字元串進行編碼的方法:escape(),encodeURI(),以及encodeURIComponent()。這幾種編碼所起的作用各不相同。
escape() 方法:
采用ISO Latin字元集對指定的字元串進行編碼。所有的空格符、标點符号、特殊字元以及其他非ASCII字元都将被轉化成%xx格式的字元編碼(xx等于該字元在字元集表裡面的編碼的16進制數字)。比如,空格符對應的編碼是%20。
不會被此方法編碼的字元: @ * / +
解碼函數unescape()
encodeURI() 方法:
把URI字元串采用UTF-8編碼格式轉化成escape格式的字元串。
不會被此方法編碼的字元:! @ # $& * ( ) = : / ; ? + '
解碼函數decodeURI()
encodeURIComponent() 方法:
把URI 字元串采用UTF-8編碼格式轉化成escape格式的字元串。與encodeURI()相比,這個方法将對更多的字元進行編碼,比如 / 等字元。是以如果字元串裡面包含了URI的幾個部分的話,不能用這個方法來進行編碼,否則 / 字元被編碼之後URL将顯示錯誤。
不會被此方法編碼的字元:! * ( ) '
解碼函數decodeURIComponent()
因 此,對于中文字元串來說,如果不希望把字元串編碼格式轉化成UTF-8格式的(比如原頁面和目标頁面的charset是一緻的時候),隻需要使用 escape。如果你的頁面是GB2312或者其他的編碼,而接受參數的頁面是UTF-8編碼的,就要采用encodeURI或者 encodeURIComponent。
另外,encodeURI/encodeURIComponent是在javascript1.5之後引進的,escape則在javascript1.0版本就有。