如何通過(guò)JS實(shí)現(xiàn)轉(zhuǎn)碼與解碼
這篇文章主要介紹了如何通過(guò)JS實(shí)現(xiàn)轉(zhuǎn)碼與解碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
escape 和 unescape
escape()不能直接用于URL編碼,它的真正作用是返回一個(gè)字符的Unicode編碼值。
采用unicode字符集對(duì)指定的字符串除0-255以外進(jìn)行編碼。所有的空格符、標(biāo)點(diǎn)符號(hào)、特殊字符以及更多有聯(lián)系非ASCII字符都將被轉(zhuǎn)化成%xx格式的字符編碼(xx等于該字符在字符集表里面的編碼的16進(jìn)制數(shù)字)。比如,空格符對(duì)應(yīng)的編碼是%20。
escape不編碼字符有69個(gè):*,+,-,.,/,@,_,0-9,a-z,A-Z。
escape()函數(shù)用于js對(duì)字符串進(jìn)行編碼。
encodeURI 和 decodeURI
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape各式的字符串。
encodeURI不編碼字符有82個(gè):!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
encodeURI()用于整個(gè)url編碼
encodeURIComponent 和 decodeURIComponent
與encodeURI()的區(qū)別是,它用于對(duì)URL的組成部分進(jìn)行個(gè)別編碼,而不用于對(duì)整個(gè)URL進(jìn)行編碼。
因此,"; / ? : @ & = + $ , #",這些在encodeURI()中不被編碼的符號(hào),在encodeURIComponent()中統(tǒng)統(tǒng)會(huì)被編碼。至于具體的編碼方法,兩者是一樣。把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。
encodeURIComponent() 用于參數(shù)的傳遞,參數(shù)包含特殊字符可能會(huì)造成間斷。
總結(jié)
escape編碼字符串
簡(jiǎn)單來(lái)說(shuō),escape是對(duì)字符串(string)進(jìn)行編碼(而另外兩種是對(duì)URL),作用是讓它們?cè)谒须娔X上可讀。
編碼之后的效果是%XX或者%uXXXX這種形式。
其中 ASCII字母 數(shù)字 @*/+ 等字符不會(huì)被編碼,其余的都會(huì)。
最關(guān)鍵的是,當(dāng)需要對(duì)URL編碼時(shí),忘記這個(gè)方法,這個(gè)方法是針對(duì)字符串使用的,不適用于URL。
URL編碼encodeURI和encodeURIComponent
對(duì)URL編碼是常見(jiàn)的事,所以這兩個(gè)方法應(yīng)該是實(shí)際中要特別注意的。它們都是編碼URL,唯一區(qū)別就是編碼的字符范圍,其中
encodeURI方法不會(huì)對(duì)下列字符編碼 ASCII字母 數(shù)字 ~!@#$&*()=:/,;?+'
encodeURIComponent方法不會(huì)對(duì)下列字符編碼 ASCII字母 數(shù)字 ~!*()'
所以encodeURIComponent比encodeURI編碼的范圍更大。
實(shí)際例子來(lái)說(shuō),encodeURIComponent會(huì)把 http:// 編碼成 http%3A%2F%2F 而encodeURI卻不會(huì)。
如果只是編碼字符串,不和URL有半毛錢(qián)關(guān)系,那么用escape。
如果你需要編碼整個(gè)URL,然后需要使用這個(gè)URL,那么用encodeURI。
比如
encodeURI(http://www.cnblogs.com/some other thing);
編碼結(jié)果:
http://www.cnblogs.com/some%20other%20thing
其中,空格被編碼成了%20。但是如果用了encodeURIComponent,那么結(jié)果變?yōu)?/p>
http%3A%2F%2Fwww.cnblogs.com%2Fseason-huang%2Fsome%20other%20thing
連 "/" 都被編碼了,整個(gè)URL已經(jīng)沒(méi)法用了。
當(dāng)需要編碼URL中的參數(shù)的時(shí)候,那么encodeURIComponent是最好方法
var param = "http://www.cnblogs.com/"; //param為參數(shù) param = encodeURIComponent(param); var url = "http://www.cnblogs.com?next=" + param; console.log(url) //http://www.cnblogs.com?next=http%3A%2F%2Fwww.cnblogs.com%2F
參數(shù)中的 "/" 可以編碼,如果用encodeURI肯定要出問(wèn)題,因?yàn)楹竺娴?是需要編碼的。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JS字符串與二進(jìn)制的相互轉(zhuǎn)化實(shí)例代碼詳解
- js實(shí)現(xiàn)unicode碼字符串與utf8字節(jié)數(shù)據(jù)互轉(zhuǎn)詳解
- 解決Pandas to_json()中文亂碼,轉(zhuǎn)化為json數(shù)組的問(wèn)題
- 詳解json string轉(zhuǎn)換為java bean及實(shí)例代碼
- JS實(shí)現(xiàn)漢字與Unicode碼相互轉(zhuǎn)換的方法詳解
- javascript使用btoa和atob來(lái)進(jìn)行Base64轉(zhuǎn)碼和解碼
- js 轉(zhuǎn)義字符及URI編碼詳解
- js中unicode轉(zhuǎn)碼方法詳解
- js unicode 編碼解析關(guān)于數(shù)據(jù)轉(zhuǎn)換為中文的兩種方法
相關(guān)文章
如何實(shí)現(xiàn)textarea里的不同文本顯示不同顏色
如何實(shí)現(xiàn)textarea里的不同文本顯示不同顏色呢?控制textarea的style設(shè)置Textarea以及把文本放到標(biāo)記里都不會(huì)起作用,下面有個(gè)不錯(cuò)的解決方法,感興趣的朋友可以了解下2014-01-01js將字符串中的每一個(gè)單詞的首字母變?yōu)榇髮?xiě)其余均為小寫(xiě)
本文主要介紹了javascript將字符串中的每一個(gè)單詞的首字母變?yōu)榇髮?xiě)其余均為小寫(xiě)的方法。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01JavaScript實(shí)現(xiàn)通過(guò)鍵盤(pán)彈鋼琴的效果實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于JavaScript實(shí)現(xiàn)通過(guò)鍵盤(pán)彈鋼琴效果的相關(guān)資料,通過(guò)JS代碼實(shí)現(xiàn)了鋼琴鍵盤(pán)的交互效果,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03JavaScript實(shí)現(xiàn)shuffle數(shù)組洗牌操作示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)shuffle數(shù)組洗牌操作,結(jié)合實(shí)例形式分析了javascript數(shù)組的定義、構(gòu)造、排序等相關(guān)操作技巧,需要的朋友可以參考下2019-01-01JS生態(tài)系統(tǒng)加速一次一庫(kù)PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索
這篇文章主要介紹了JS生態(tài)系統(tǒng)加速一次一庫(kù)PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01屏蔽網(wǎng)頁(yè)右鍵復(fù)制和ctrl+c復(fù)制的js代碼
解決的方法就是直接把網(wǎng)頁(yè)保存下來(lái)然后刪掉下面這段js代碼,然后就可以正常用右鍵菜單,也可以通過(guò)設(shè)置瀏覽器的安全級(jí)別到最高級(jí)別來(lái)解決問(wèn)題2013-01-01使用canvas及js簡(jiǎn)單生成驗(yàn)證碼方法
在很多時(shí)候都需要用到驗(yàn)證碼,前端驗(yàn)證碼需要知道Html5中的canvas知識(shí)點(diǎn)。驗(yàn)證碼生成步驟是:1.生成一張畫(huà)布canvas 2.生成隨機(jī)數(shù)驗(yàn)證碼 3.在畫(huà)布中生成干擾線(xiàn) 4.把驗(yàn)證碼文本填充到畫(huà)布中 5.點(diǎn)擊畫(huà)布更換驗(yàn)證碼2017-04-04JS實(shí)現(xiàn)網(wǎng)頁(yè)上隨機(jī)產(chǎn)生超鏈接地址的方法
這篇文章主要介紹了JS實(shí)現(xiàn)網(wǎng)頁(yè)上隨機(jī)產(chǎn)生超鏈接地址的方法,涉及JavaScript隨機(jī)數(shù)的相關(guān)使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11