這是我參與8月更文挑戰的第6天,活動詳情查看:8月更文挑戰javascript
JavaScript中有幾個能夠對字符串編碼的函數,分別是:escape、encodeURI、encodeURIComponent。java
要素 | 描述 |
---|---|
定義 | escape() 函數可對字符串進行編碼,這樣就能夠在全部的計算機上讀取該字符串 |
語法 | escape(string) |
參數描述 | escape() 函數可對字符串進行編碼,這樣就能夠在全部的計算機上讀取該字符串 |
返回值 | 已編碼的 string 的副本,其中某些字符被替換成了十六進制的轉義序列 |
說明 | 該方法不會對 ASCII 字母和數字進行編碼,也不會對下面這些 ASCII 標點符號進行編碼: - _ . ! ~ * ' ( ) 。其餘全部的字符都會被轉義序列替換。 |
解碼 | unescape() |
提示 | ECMAScript v3 反對使用該方法,應用使用 decodeURI() 和 decodeURIComponent() 替代它 |
const a1 = 'Visit W3School!';
const b1 = '?!=()#%&'
console.log(escape(a1)); // Visit%20W3School%21
console.log(escape(b1)); // %3F%21%3D%28%29%23%25%26
const a2 = 'Visit%20W3School%21';
const b2 = '3F%21%3D%28%29%23%25%26';
console.log(unescape(a2)); // Visit W3School!
console.log(unescape(b2)); // ?!=()#%&
複製代碼
要素 | 描述 |
---|---|
定義 | encodeURI() 函數可把字符串做爲 URI 進行編碼 |
語法 | encodeURI(URIstring) |
參數描述 | URIstring 必需。一個字符串,含有 URI 或其餘要編碼的文本。 |
返回值 | URIstring 的副本,其中的某些字符將被十六進制的轉義序列進行替換 |
說明 | 該方法不會對 ASCII 字母和數字進行編碼,也不會對這些 ASCII 標點符號進行編碼: - _ . ! ~ * ' ( ) 。該方法的目的是對 URI 進行完整的編碼,所以對如下在 URI 中具備特殊含義的 ASCII 標點符號,encodeURI() 函數是不會進行轉義的:; / ? : @ & = + $ , #。 |
解碼 | decodeURI() |
提示 | 若是 URI 組件中含有分隔符,好比 ? 和 #,則應當使用 encodeURIComponent() 方法分別對各組件進行編碼 |
const a1 = 'http://www.w3school.com.cn/My first/';
const b1 = ',/?:@&=+$#'
console.log(encodeURI(a1)); // http://www.w3school.com.cn/My%20first/
console.log(encodeURI(b1)); // ,/?:@&=+$#
const a2 = 'http://www.w3school.com.cn/My%20first/';
const b2 = ',/?:@&=+$#';
console.log(decodeURI(a2)); // http://www.w3school.com.cn/My first/
console.log(decodeURI(b2)); // ,/?:@&=+$#
複製代碼
要素 | 描述 |
---|---|
定義 | encodeURIComponent() 函數可把字符串做爲 URI 組件進行編碼 |
語法 | encodeURIComponent(URIstring) |
參數描述 | URIstring 必需。一個字符串,含有 URI 組件或其餘要編碼的文本 |
返回值 | URIstring 的副本,其中的某些字符將被十六進制的轉義序列進行替換 |
說明 | 該方法不會對 ASCII 字母和數字進行編碼,也不會對這些 ASCII 標點符號進行編碼: - _ . ! ~ * ' ( ) 。其餘字符(好比 :; / ? : @ & = + $ , # 這些用於分隔 URI 組件的標點符號),都是由一個或多個十六進制的轉義序列替換的。 |
解碼 | decodeURIComponent() |
提示 | 注意: encodeURIComponent() 函數 與 encodeURI() 函數的區別,前者假定它的參數是 URI 的一部分(好比協議、主機名、路徑或查詢字符串)。所以 encodeURIComponent() 函數將轉義用於分隔 URI 各個部分的標點符號。 |
const a1 = 'http://www.w3school.com.cn/My first/';
const b1 = ',/?:@&=+$#'
console.log(encodeURIComponent(a1)); // http%3A%2F%2Fwww.w3school.com.cn%2FMy%20first%2F
console.log(encodeURIComponent(b1)); // ,%2C%2F%3F%3A%40%26%3D%2B%24%23
const a2 = 'http%3A%2F%2Fwww.w3school.com.cn%2FMy%20first%2F';
const b2 = '%2C%2F%3F%3A%40%26%3D%2B%24%23';
console.log(decodeURIComponent(a2)); // http://www.w3school.com.cn/My first/
console.log(decodeURIComponent(b2)); // ,/?:@&=+$#
複製代碼
總結:markdown
經過對三個函數的分析,咱們知道:escape() 除了 ASCII 字母、數字和特定的符號外,對傳進來的字符串所有進行轉義編碼,所以若是想對 URL 編碼,最好不要使用此方法。而 encodeURI() 用於編碼整個 URI,由於 URI 中的合法字符都不會被編碼轉換。encodeURIComponent 方法在編碼單個 URIComponent(指請求參數)應當是最經常使用的,它能夠講參數中的中文、特殊字符進行轉義,而不會影響整個URL。函數