js對url進行編碼解碼的三種方式總結(jié)
方法 | 說明 | 返回值 |
---|---|---|
escape(String) | 使用轉(zhuǎn)義序列替換某些字符來對字符串進行編碼,除了ASCII字母、數(shù)字、標點符號"@ * _ + - . /"以外 | 返回Unicode編碼字符串 |
unescape(String) | 對使用 escape() 編碼的字符串進行解碼 | |
encodeURI(String) | 通過轉(zhuǎn)義某些字符對 URI 進行編碼,除了常見的符號以外(ASCII 字符),對其他一些在網(wǎng)址中有特殊含義的符號"; / ? : @ & = + $ , #",也不進行編碼 | 輸出utf-8形式字符串 |
decodeURI(String) | 對使用 encodeURI() 方法編碼的字符串進行解碼 | |
encodeURIComponent(String) | 通過某些轉(zhuǎn)義字符對 URI 進行編碼,會編譯所有(包含特殊字符),ASCII 字符不編碼,可以將參數(shù)中的中文、特殊字符進行轉(zhuǎn)義 | 輸出utf-8形式字符串 |
deencodeURIComponent(String) | 對使用 encodeURIComponent() 方法編碼的字符串進行解碼 |
第一種:escape 和 unescape
escape()不能直接用于URL編碼,它的真正作用是返回一個字符的Unicode編碼值
它的具體規(guī)則是,除了ASCII字母、數(shù)字、標點符號"@ * _ + - . /"以外,對其他所有字符進行編碼。在u0000到u00ff之間的符號被轉(zhuǎn)成%xx的形式,其余符號被轉(zhuǎn)成%uxxxx的形式。對應(yīng)的解碼函數(shù)是unescape()。
還有兩個點需要注意:
- 首先,無論網(wǎng)頁的原始編碼是什么,一旦被Javascript編碼,就都變?yōu)閡nicode字符。也就是說,Javascipt函數(shù)的輸入和輸出,默認都是Unicode字符。這一點對下面兩個函數(shù)也適用。
- 其次,escape()不對 "+" 編碼。但是我們知道,網(wǎng)頁在提交表單的時候,如果有空格,則會被轉(zhuǎn)化為+字符。服務(wù)器處理數(shù)據(jù)的時候,會把+號處理成空格。所以,使用的時候要小心。
escape()編碼: const time = 2022-01-09 const tile = '63元黑糖顆粒固飲' let url = "http://localhost:8080/index.html?time="+escape(time)+"&title="+escape(tile) 地址欄顯示結(jié)果: "http://localhost:8080/index.html?time=2022-01-09&title=63%u5143%u9ED1%u7CD6%u9897%u7C92%u56FA%u996E"
unescape()解碼: let url = "http://localhost:8080/index.html?time="+unescape(2022-01-09)+"&title="+unescape(63%u5143%u9ED1%u7CD6%u9897%u7C92%u56FA%u996E) 地址欄顯示結(jié)果: "http://localhost:8080/index.html?time=2022-01-09&title=63元黑糖顆粒固飲"
第二種:encodeURI 和 decodeURI
encodeURI()是Javascript中真正用來對URL編碼的函數(shù)。
它用于對URL的組成部分進行個別編碼,除了常見的符號以外,對其他一些在網(wǎng)址中有特殊含義的符號"; / ? : @ & = + $ , #",也不進行編碼。編碼后,它輸出符號的utf-8形式,并且在每個字節(jié)前加上%,,然后用十六進制的轉(zhuǎn)義序列(形式為%xx)對生成的 1 字節(jié)、2 字節(jié)或 4 字節(jié)的字符進行編碼。
它對應(yīng)的解碼函數(shù)是decodeURI()
需要注意的是,它不對單引號'編碼。
let url = "http://localhost:8080/index.html?time=2022-01-09&title=63元黑糖顆粒固飲" encodeURI()編碼: let encodeURI_url = encodeURI(url) = "http://localhost:8080/index.html?time=2022-01-09&title=63%E5%85%83%E9%BB%91%E7%B3%96%E9%A2%97%E7%B2%92%E5%9B%BA%E9%A5%AE" decodeURI()解碼: decodeURI(encodeURI_url )= “http://localhost:8080/index.html?time=2022-01-09&title=63元黑糖顆粒固飲”
第三種:encodeURIComponent 和 decodeURIComponent
與encodeURI()的區(qū)別是,它用于對整個URL進行編碼。"; / ? : @ & = + $ , #",這些在encodeURI()中不被編碼的符號,在encodeURIComponent()中統(tǒng)統(tǒng)會被編碼。
它對應(yīng)的解碼函數(shù)是decodeURIComponent()。
let url = "http://localhost:8080/index.html?time=2022-01-09&title=63元黑糖顆粒固飲" encodeURIComponent ()編碼: let encodeURIComponent _url = encodeURIComponent (url) = http%3A%2F%2Flocalhost%3A8080%2Findex.html%3Ftime%3D2022-01-09%26title%3D63%E5%85%83%E9%BB%91%E7%B3%96%E9%A2%97%E7%B2%92%E5%9B%BA%E9%A5%AE decodeURIComponent()解碼: decodeURIComponent(encodeURIComponent _url )= “http://localhost:8080/index.html?time=2022-01-09&title=63元黑糖顆粒固飲”
總結(jié)
到此這篇關(guān)于js對url進行編碼解碼的三種方式的文章就介紹到這了,更多相關(guān)js對url編碼解碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
layui 關(guān)閉open彈出框 刷新table表格頁面的方法
今天小編就為大家分享一篇layui 關(guān)閉open彈出框 刷新table表格頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09CocosCreator經(jīng)典入門項目之flappybird
這篇文章主要介紹了CocosCreator經(jīng)典入門項目之flappybird,詳細說明了制作的每個步驟,還有詳盡的代碼,對CocosCreator感興趣的同學,一定要看一下2021-04-04