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

