1.escape();
語法:
escape(string) // string 必需。要被轉義或編碼的字符串。
返回值:
已編碼的 string 的副本。其中某些字符被替換成了十六進制的轉義序列。
說明:
該方法不會對 ASCII 字母和數字進行編碼,也不會對下面這些 ASCII 標點符號進行編碼:** * @ - _ + . / **
解碼:
unescape();
提示:
ECMAScript v3 反對使用該方法,用 encodeURI() 和 encodeURIComponent() 替代它。但是如果想轉義單引號,用這個就蠻好的。
例子:
console.log(escape("Visit W3School!")) //Visit%20W3School%21
console.log(escape("?!=()#%&")) //%3F%21%3D%28%29%23%25%26
console.log(escape("*@-_+./")) //*@-_+./
console.log(escape("'")) //%27
2.encodeURI();
語法:
encodeURI(URIstring) // URIstring 必需。一個字符串,含有 URI 或其他要編碼的文本。
返回值:
已編碼的 URIstring 的副本,其中的某些字符將被十六進制的轉義序列進行替換。
說明:
該方法不會對 ASCII 字母和數字進行編碼,也不會對這些 ASCII 標點符號進行編碼:** - _ . ! ~ * ' ( ) **
該方法的目的是對 URI 進行完整的編碼,因此對以下在 URI 中具有特殊含義的 ASCII 標點符號,encodeURI() 函數是不會進行轉義的:;/?:@&=+$,#
提示:
如果 URI 組件中含有分隔符,比如 ? 和 #,則應當使用 encodeURIComponent() 方法分別對各組件進行編碼。
例子:
console.log(encodeURI("http://www.w3school.com.cn")) //http://www.w3school.com.cn
console.log(encodeURI("http://www.w3school.com.cn/yzb/")) //http://www.w3school.com.cn/yzb/
console.log(encodeURI(";/?:@&=+$,#")) //;/?:@&=+$,#
console.log(encodeURI("-_.!~*'()")) //-_.!~*'()
console.log(encodeURI(" ")) //%20
3.encodeURIComponent();
語法:
encodeURIComponent(URIstring) // URIstring 必需。一個字符串,含有 URI 組件或其他要編碼的文本。
返回值:
已編碼的 URIstring 的副本,其中的某些字符將被十六進制的轉義序列進行替換。
說明:
該方法不會對 ASCII 字母和數字進行編碼,也不會對這些 ASCII 標點符號進行編碼: ** - _ . ! ~ * ' ( ) **
其他字符(比如:** ;/?:@&=+$,# ** 這些用于分隔 URI 組件的標點符號),都是由一個或多個十六進制的轉義序列替換的。
提示:
請注意 encodeURIComponent() 函數 與 encodeURI() 函數的區別之處,前者假定它的參數是 URI 的一部分(比如協議、主機名、路徑或查詢字符串)。因此 encodeURIComponent() 函數將轉義用于分隔 URI 各個部分的標點符號。
例子:
console.log(encodeURIComponent("http://www.w3school.com.cn")) //http%3A%2F%2Fwww.w3school.com.cn
console.log(encodeURIComponent("http://www.w3school.com.cn/yzb/")) //http%3A%2F%2Fwww.w3school.com.cn%2Fyzb%2F
console.log(encodeURIComponent(";/?:@&=+$,#")) //%3B%2F%3F%3A%40%26%3D%2B%24%2C%23
console.log(encodeURIComponent("-_.!~*'()")) //-_.!~*'()
console.log(encodeURIComponent(" ")) //%20