js對(duì)url進(jìn)行編碼解碼的三種方式總結(jié)
方法 | 說(shuō)明 | 返回值 |
---|---|---|
escape(String) | 使用轉(zhuǎn)義序列替換某些字符來(lái)對(duì)字符串進(jìn)行編碼,除了ASCII字母、數(shù)字、標(biāo)點(diǎn)符號(hào)"@ * _ + - . /"以外 | 返回Unicode編碼字符串 |
unescape(String) | 對(duì)使用 escape() 編碼的字符串進(jìn)行解碼 | |
encodeURI(String) | 通過(guò)轉(zhuǎn)義某些字符對(duì) URI 進(jìn)行編碼,除了常見(jiàn)的符號(hào)以外(ASCII 字符),對(duì)其他一些在網(wǎng)址中有特殊含義的符號(hào)"; / ? : @ & = + $ , #",也不進(jìn)行編碼 | 輸出utf-8形式字符串 |
decodeURI(String) | 對(duì)使用 encodeURI() 方法編碼的字符串進(jìn)行解碼 | |
encodeURIComponent(String) | 通過(guò)某些轉(zhuǎn)義字符對(duì) URI 進(jìn)行編碼,會(huì)編譯所有(包含特殊字符),ASCII 字符不編碼,可以將參數(shù)中的中文、特殊字符進(jìn)行轉(zhuǎn)義 | 輸出utf-8形式字符串 |
deencodeURIComponent(String) | 對(duì)使用 encodeURIComponent() 方法編碼的字符串進(jìn)行解碼 |
第一種:escape 和 unescape
escape()不能直接用于URL編碼,它的真正作用是返回一個(gè)字符的Unicode編碼值
它的具體規(guī)則是,除了ASCII字母、數(shù)字、標(biāo)點(diǎn)符號(hào)"@ * _ + - . /"以外,對(duì)其他所有字符進(jìn)行編碼。在u0000到u00ff之間的符號(hào)被轉(zhuǎn)成%xx的形式,其余符號(hào)被轉(zhuǎn)成%uxxxx的形式。對(duì)應(yīng)的解碼函數(shù)是unescape()。
還有兩個(gè)點(diǎn)需要注意:
- 首先,無(wú)論網(wǎng)頁(yè)的原始編碼是什么,一旦被Javascript編碼,就都變?yōu)閡nicode字符。也就是說(shuō),Javascipt函數(shù)的輸入和輸出,默認(rèn)都是Unicode字符。這一點(diǎn)對(duì)下面兩個(gè)函數(shù)也適用。
- 其次,escape()不對(duì) "+" 編碼。但是我們知道,網(wǎng)頁(yè)在提交表單的時(shí)候,如果有空格,則會(huì)被轉(zhuǎn)化為+字符。服務(wù)器處理數(shù)據(jù)的時(shí)候,會(huì)把+號(hào)處理成空格。所以,使用的時(shí)候要小心。
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中真正用來(lái)對(duì)URL編碼的函數(shù)。
它用于對(duì)URL的組成部分進(jìn)行個(gè)別編碼,除了常見(jiàn)的符號(hào)以外,對(duì)其他一些在網(wǎng)址中有特殊含義的符號(hào)"; / ? : @ & = + $ , #",也不進(jìn)行編碼。編碼后,它輸出符號(hào)的utf-8形式,并且在每個(gè)字節(jié)前加上%,,然后用十六進(jìn)制的轉(zhuǎn)義序列(形式為%xx)對(duì)生成的 1 字節(jié)、2 字節(jié)或 4 字節(jié)的字符進(jìn)行編碼。
它對(duì)應(yīng)的解碼函數(shù)是decodeURI()
需要注意的是,它不對(duì)單引號(hào)'編碼。
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ū)別是,它用于對(duì)整個(gè)URL進(jìn)行編碼。"; / ? : @ & = + $ , #",這些在encodeURI()中不被編碼的符號(hào),在encodeURIComponent()中統(tǒng)統(tǒng)會(huì)被編碼。
它對(duì)應(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對(duì)url進(jìn)行編碼解碼的三種方式的文章就介紹到這了,更多相關(guān)js對(duì)url編碼解碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
layui 關(guān)閉open彈出框 刷新table表格頁(yè)面的方法
今天小編就為大家分享一篇layui 關(guān)閉open彈出框 刷新table表格頁(yè)面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09javascript寫的一個(gè)鏈表實(shí)現(xiàn)代碼
今天在百度上看到有人問(wèn)怎么用Javascript 寫一個(gè)學(xué)生管理系統(tǒng)。個(gè)人認(rèn)為沒(méi)有什么實(shí)現(xiàn)價(jià)值。無(wú)聊練練手吧,很久沒(méi)寫JS了。2009-10-10CocosCreator經(jīng)典入門項(xiàng)目之flappybird
這篇文章主要介紹了CocosCreator經(jīng)典入門項(xiàng)目之flappybird,詳細(xì)說(shuō)明了制作的每個(gè)步驟,還有詳盡的代碼,對(duì)CocosCreator感興趣的同學(xué),一定要看一下2021-04-04JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼
這篇文章主要為大家詳細(xì)介紹了JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06