亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2023年02月14日 14:36:52   作者:muzidigbig  
為一個字符串進行URL編碼很容易,只需要調(diào)用encodeURI,傳入要編碼的字符串即可,而且實現(xiàn)的方法不止這一個,下面這篇文章主要給大家介紹了關(guān)于js對url進行編碼解碼的三種方式,需要的朋友可以參考下
方法說明返回值
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()。

還有兩個點需要注意:

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

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

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

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

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

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

    JS與C#編碼解碼

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

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

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

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

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

    JS閉包用法實例分析

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

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

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

    javascript寫的一個鏈表實現(xiàn)代碼

    今天在百度上看到有人問怎么用Javascript 寫一個學生管理系統(tǒng)。個人認為沒有什么實現(xiàn)價值。無聊練練手吧,很久沒寫JS了。
    2009-10-10
  • CocosCreator經(jīng)典入門項目之flappybird

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

    這篇文章主要介紹了CocosCreator經(jīng)典入門項目之flappybird,詳細說明了制作的每個步驟,還有詳盡的代碼,對CocosCreator感興趣的同學,一定要看一下
    2021-04-04
  • JavaScript注冊時密碼強度校驗代碼

    JavaScript注冊時密碼強度校驗代碼

    這篇文章主要為大家詳細介紹了JavaScript注冊時密碼強度校驗代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評論