欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js對(duì)url進(jìn)行編碼解碼的三種方式總結(jié)

 更新時(shí)間:2023年02月14日 14:36:52   作者:muzidigbig  
為一個(gè)字符串進(jìn)行URL編碼很容易,只需要調(diào)用encodeURI,傳入要編碼的字符串即可,而且實(shí)現(xiàn)的方法不止這一個(gè),下面這篇文章主要給大家介紹了關(guān)于js對(duì)url進(jìn)行編碼解碼的三種方式,需要的朋友可以參考下
方法說明返回值
escape(String)使用轉(zhuǎn)義序列替換某些字符來對(duì)字符串進(jìn)行編碼,除了ASCII字母、數(shù)字、標(biāo)點(diǎn)符號(hào)"@ * _ + - . /"以外返回Unicode編碼字符串
unescape(String)對(duì)使用 escape() 編碼的字符串進(jìn)行解碼
encodeURI(String)通過轉(zhuǎn)義某些字符對(duì) URI 進(jìn)行編碼,除了常見的符號(hào)以外(ASCII 字符),對(duì)其他一些在網(wǎng)址中有特殊含義的符號(hào)"; / ? : @ & = + $ , #",也不進(jìn)行編碼輸出utf-8形式字符串
decodeURI(String)對(duì)使用 encodeURI() 方法編碼的字符串進(jìn)行解碼
encodeURIComponent(String)通過某些轉(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)需要注意:

  1. 首先,無論網(wǎng)頁的原始編碼是什么,一旦被Javascript編碼,就都變?yōu)閡nicode字符。也就是說,Javascipt函數(shù)的輸入和輸出,默認(rèn)都是Unicode字符。這一點(diǎn)對(duì)下面兩個(gè)函數(shù)也適用。
  2. 其次,escape()不對(duì) "+" 編碼。但是我們知道,網(wǎng)頁在提交表單的時(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中真正用來對(duì)URL編碼的函數(shù)。

它用于對(duì)URL的組成部分進(jìn)行個(gè)別編碼,除了常見的符號(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)文章

最新評(píng)論