JS中三種URI編碼方式對比分析
一、實例比較
數(shù)據(jù)傳遞常需要編碼后傳遞,接收還需反編譯,定義url:
var url = "https://www.cnblogs.com/?username='小森森'&password='666666'";
escape 與 unescape
console.log(escape(url));// 編碼 console.log(unescape(escape(url)));// 解碼
結(jié)果:
https%3A//www.cnblogs.com/%3Fusername%3D%27%u5C0F%u68EE%u68EE%27%26password%3D%27666666%27
encodeURIComponent 與 decodeURIComponent (推薦)
console.log(encodeURIComponent(url));// 編碼 console.log(decodeURIComponent(encodeURIComponent(url)));// 解碼
結(jié)果:
https%3A%2F%2Fwww.cnblogs.com%2F%3Fusername%3D'%E5%B0%8F%E6%A3%AE%E6%A3%AE'%26password%3D'666666'
encodeURI 與 decodeURI
console.log(encodeURI(url));// 編碼 console.log(decodeURI(encodeURI(url)));// 解碼
結(jié)果:
https://www.cnblogs.com/?username='%E5%B0%8F%E6%A3%AE%E6%A3%AE'&password='666666'
二、區(qū)別分析
三種方法都不會對 ASCII 字母、數(shù)字和規(guī)定的特殊 ASCII 標點符號進行編碼,其余都替換為十六進制轉(zhuǎn)義序列.
escape 與 unescape
escape不編碼字符有69個:*,+,-,.,/,@,_,0-9,a-z,A-Z
對字符串全部進行轉(zhuǎn)義編碼,ECMAScript v3 反對使用該方法,對URL編碼勿使用此方法
encodeURIComponent 與 decodeURIComponent
encodeURIComponent不編碼字符有71個:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z
傳遞參數(shù)時需使用encodeURIComponent
,組合的url才不會被#等特殊字符截斷
encodeURI 與 decodeURI
encodeURI不編碼字符有82個:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
進行url跳轉(zhuǎn)時可以整體使用encodeURI
,如果URI中含分隔符如 ? 和 #,應使用encodeURIComponent
三、結(jié)論
推薦使用encodeURIComponent
到此這篇關(guān)于JS中三種URI編碼方式比較的文章就介紹到這了,更多相關(guān)js URI編碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- JavaScript使用escape()、encodeURI()和decodeURI()實現(xiàn)URI編碼解碼
- js中編碼函數(shù):escape,encodeURI與encodeURIComponent詳解
- js 轉(zhuǎn)義字符及URI編碼詳解
- js中字符串編碼函數(shù)escape()、encodeURI()、encodeURIComponent()區(qū)別詳解
- 從此不再懼怕URI編碼 JavaScript及C# URI編碼詳解
- js編碼之encodeURIComponent使用介紹(asp,php)
- Javascript下的urlencode編碼解碼方法附decodeURIComponent
相關(guān)文章
JS基于遞歸實現(xiàn)網(wǎng)頁版計算器的方法分析
這篇文章主要介紹了JS基于遞歸實現(xiàn)網(wǎng)頁版計算器的方法,結(jié)合實例形式分析了javascript采用遞歸算法實現(xiàn)網(wǎng)頁版計算器的步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-12-12使用?Schema-Utils?對?Webpack?Plugin?進行配置項校驗的簡單用例
schema-utils?庫用于在?loader?和?plugin?實例化時,對傳入的參數(shù)進行校驗,本文重點給大家介紹使用?Schema-Utils?對?Webpack?Plugin?進行配置項校驗的用例詳解,感興趣的朋友一起看看吧2022-03-03基于Bootstrap的Metronic框架實現(xiàn)條碼和二維碼的生成及打印處理操作
這篇文章主要介紹了基于Bootstrap的Metronic框架實現(xiàn)條碼和二維碼的生成及打印處理操作的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08js前端加密庫Crypto-js進行MD5/SHA256/BASE64/AES加解密的方法與示例
js加密解密可以使用crypto-js它可以進行MD5、SHA-1、SHA-256、Base64、AES、DES、等算法和加密,這是一個對稱加密的庫,可以使用 AES、DES、但沒有rsa等非對稱加密的方法2023-12-12