欧美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)行編碼解碼的三種方式,需要的朋友可以參考下
方法說(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)需要注意:

  1. 首先,無(wú)論網(wǎng)頁(yè)的原始編碼是什么,一旦被Javascript編碼,就都變?yōu)閡nicode字符。也就是說(shuō),Javascipt函數(shù)的輸入和輸出,默認(rèn)都是Unicode字符。這一點(diǎn)對(duì)下面兩個(gè)函數(shù)也適用。
  2. 其次,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)文章

  • 微信公眾號(hào)支付H5調(diào)用支付解析

    微信公眾號(hào)支付H5調(diào)用支付解析

    這篇文章主要為大家詳細(xì)介紹了微信公眾號(hào)支付H5調(diào)用支付,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • layui 關(guān)閉open彈出框 刷新table表格頁(yè)面的方法

    layui 關(guān)閉open彈出框 刷新table表格頁(yè)面的方法

    今天小編就為大家分享一篇layui 關(guān)閉open彈出框 刷新table表格頁(yè)面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • JS與C#編碼解碼

    JS與C#編碼解碼

    這篇文章主要是對(duì)JS與C#編碼解碼進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-12-12
  • 可以將word轉(zhuǎn)成html的js代碼

    可以將word轉(zhuǎn)成html的js代碼

    這段很短的代碼,可以將word轉(zhuǎn)出html格式的代碼,當(dāng)然word自己也帶的,另存為里面就有的,喜歡的朋友可以試試。
    2010-04-04
  • 如何調(diào)試異步加載頁(yè)面里包含的js文件

    如何調(diào)試異步加載頁(yè)面里包含的js文件

    用瀏覽器無(wú)法調(diào)試異步加載頁(yè)面里包含的js文件。簡(jiǎn)單的說(shuō)就是在調(diào)試工具里面看不到異步加載頁(yè)面里包含的js文件
    2014-10-10
  • JS閉包用法實(shí)例分析

    JS閉包用法實(shí)例分析

    這篇文章主要介紹了JS閉包用法,結(jié)合具體實(shí)例形式分析了javascript閉包的原理、執(zhí)行步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2017-03-03
  • 分析uniapp如何動(dòng)態(tài)獲取接口域名

    分析uniapp如何動(dòng)態(tài)獲取接口域名

    本文主要介紹了uniapp如何動(dòng)態(tài)獲取接口域名,感興趣的同學(xué),可以參考下,并且試驗(yàn)一下。
    2021-06-06
  • javascript寫的一個(gè)鏈表實(shí)現(xiàn)代碼

    javascript寫的一個(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-10
  • CocosCreator經(jīng)典入門項(xiàng)目之flappybird

    CocosCreator經(jīng)典入門項(xiàng)目之flappybird

    這篇文章主要介紹了CocosCreator經(jīng)典入門項(xiàng)目之flappybird,詳細(xì)說(shuō)明了制作的每個(gè)步驟,還有詳盡的代碼,對(duì)CocosCreator感興趣的同學(xué),一定要看一下
    2021-04-04
  • JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼

    JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼

    這篇文章主要為大家詳細(xì)介紹了JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評(píng)論