欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何通過JS實(shí)現(xiàn)轉(zhuǎn)碼與解碼

 更新時(shí)間:2020年02月21日 11:27:36   作者:秋夜雨巷  
這篇文章主要介紹了如何通過JS實(shí)現(xiàn)轉(zhuǎn)碼與解碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這篇文章主要介紹了如何通過JS實(shí)現(xiàn)轉(zhuǎn)碼與解碼,文中通過示例代碼介紹的非常詳細(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編碼字符串

簡單來說,escape是對(duì)字符串(string)進(jìn)行編碼(而另外兩種是對(duì)URL),作用是讓它們在所有電腦上可讀。

編碼之后的效果是%XX或者%uXXXX這種形式。

其中 ASCII字母 數(shù)字 @*/+ 等字符不會(huì)被編碼,其余的都會(huì)。

最關(guān)鍵的是,當(dāng)需要對(duì)URL編碼時(shí),忘記這個(gè)方法,這個(gè)方法是針對(duì)字符串使用的,不適用于URL。

URL編碼encodeURI和encodeURIComponent

對(duì)URL編碼是常見的事,所以這兩個(gè)方法應(yīng)該是實(shí)際中要特別注意的。它們都是編碼URL,唯一區(qū)別就是編碼的字符范圍,其中

encodeURI方法不會(huì)對(duì)下列字符編碼 ASCII字母 數(shù)字 ~!@#$&*()=:/,;?+'

encodeURIComponent方法不會(huì)對(duì)下列字符編碼 ASCII字母 數(shù)字 ~!*()'

所以encodeURIComponent比encodeURI編碼的范圍更大。

實(shí)際例子來說,encodeURIComponent會(huì)把 http:// 編碼成 http%3A%2F%2F 而encodeURI卻不會(huì)。

如果只是編碼字符串,不和URL有半毛錢關(guān)系,那么用escape。

如果你需要編碼整個(gè)URL,然后需要使用這個(gè)URL,那么用encodeURI。
比如

編碼結(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)沒法用了。

當(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肯定要出問題,因?yàn)楹竺娴?是需要編碼的。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解微信小程序中組件通訊

    詳解微信小程序中組件通訊

    在本篇文章里我們給大家分享了微信小程序中組件通訊的相關(guān)知識(shí)點(diǎn)以及相關(guān)實(shí)例代碼,有興趣的朋友們學(xué)習(xí)分享下。
    2018-10-10
  • JavaScript實(shí)現(xiàn)通過鍵盤彈鋼琴的效果實(shí)例代碼

    JavaScript實(shí)現(xiàn)通過鍵盤彈鋼琴的效果實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于JavaScript實(shí)現(xiàn)通過鍵盤彈鋼琴效果的相關(guān)資料,通過JS代碼實(shí)現(xiàn)了鋼琴鍵盤的交互效果,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • JavaScript實(shí)現(xiàn)shuffle數(shù)組洗牌操作示例

    JavaScript實(shí)現(xiàn)shuffle數(shù)組洗牌操作示例

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)shuffle數(shù)組洗牌操作,結(jié)合實(shí)例形式分析了javascript數(shù)組的定義、構(gòu)造、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • JS生態(tài)系統(tǒng)加速一次一庫PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索

    JS生態(tài)系統(tǒng)加速一次一庫PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索

    這篇文章主要介紹了JS生態(tài)系統(tǒng)加速一次一庫PostCSS SVGO的重構(gòu)源碼和性能優(yōu)化探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • 屏蔽網(wǎng)頁右鍵復(fù)制和ctrl+c復(fù)制的js代碼

    屏蔽網(wǎng)頁右鍵復(fù)制和ctrl+c復(fù)制的js代碼

    解決的方法就是直接把網(wǎng)頁保存下來然后刪掉下面這段js代碼,然后就可以正常用右鍵菜單,也可以通過設(shè)置瀏覽器的安全級(jí)別到最高級(jí)別來解決問題
    2013-01-01
  • 使用canvas及js簡單生成驗(yàn)證碼方法

    使用canvas及js簡單生成驗(yàn)證碼方法

    在很多時(shí)候都需要用到驗(yàn)證碼,前端驗(yàn)證碼需要知道Html5中的canvas知識(shí)點(diǎn)。驗(yàn)證碼生成步驟是:1.生成一張畫布canvas 2.生成隨機(jī)數(shù)驗(yàn)證碼 3.在畫布中生成干擾線 4.把驗(yàn)證碼文本填充到畫布中 5.點(diǎn)擊畫布更換驗(yàn)證碼
    2017-04-04
  • 理解javascript中DOM事件

    理解javascript中DOM事件

    這篇文章主要幫助大家理解javascript中DOM事件,解決了DOM事件的兼容性,DOM事件的冒泡,以及DOM事件的重用,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JS實(shí)現(xiàn)網(wǎng)頁上隨機(jī)產(chǎn)生超鏈接地址的方法

    JS實(shí)現(xiàn)網(wǎng)頁上隨機(jī)產(chǎn)生超鏈接地址的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)網(wǎng)頁上隨機(jī)產(chǎn)生超鏈接地址的方法,涉及JavaScript隨機(jī)數(shù)的相關(guān)使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • 最新評(píng)論