js 編碼與解碼

js對(duì)文字進(jìn)行編碼涉及3個(gè)函數(shù):escape,encodeURI,encodeURIComponent脱惰,相應(yīng)3個(gè)解碼函數(shù):unescape,decodeURI,decodeURIComponent
介紹:
1 escape()函數(shù)
定義和用法
escape() 函數(shù)將字符串編碼成UNICODE格式绢馍,這樣就可以在所有的計(jì)算機(jī)上讀取該字符串疏虫。

語法
escape(string)

參數(shù) 描述
string 必需絮记。要被轉(zhuǎn)義或編碼的字符串灾梦。

返回值
已編碼的 string 的副本恳守。其中某些字符被替換成了十六進(jìn)制的轉(zhuǎn)義序列峦耘。

說明
該方法不會(huì)對(duì) ASCII 字母和數(shù)字進(jìn)行編碼驳概,也不會(huì)對(duì)下面這些 ASCII 標(biāo)點(diǎn)符號(hào)進(jìn)行編碼:-_.*。其他所有的字符都會(huì)被轉(zhuǎn)義序列替換旷赖。

解碼
可以用JS的unescape函數(shù)解決顺又,Java直接用System.out.println(); 打印出來

空格會(huì)轉(zhuǎn)為%20

2 encodeURI()函數(shù)
定義和用法
encodeURI() 函數(shù)可把字符串作為 URI 進(jìn)行編碼。

語法
encodeURI(URIstring)

參數(shù) 描述
URIstring 必需等孵。一個(gè)字符串稚照,含有 URI 或其他要編碼的文本。

返回值
URIstring 的副本俯萌,其中的某些字符將被十六進(jìn)制的轉(zhuǎn)義序列進(jìn)行替換果录。

說明
該方法不會(huì)對(duì) ASCII 字母和數(shù)字進(jìn)行編碼,也不會(huì)對(duì)這些 ASCII 標(biāo)點(diǎn)符號(hào)進(jìn)行編碼:-_.!~*'() 咐熙。

該方法的目的是對(duì) URI 進(jìn)行完整的編碼弱恒,因此對(duì)以下在 URI 中具有特殊含義的 ASCII 標(biāo)點(diǎn)符號(hào),encodeURI() 函數(shù)是不會(huì)進(jìn)行轉(zhuǎn)義的:;/?:@&=+$,#

3 encodeURIComponent() 函數(shù)

定義和用法
encodeURIComponent() 函數(shù)可把字符串作為 URI 組件進(jìn)行編碼糖声。

語法
encodeURIComponent(URIstring)

參數(shù) 描述
URIstring 必需斤彼。一個(gè)字符串分瘦,含有 URI 組件或其他要編碼的文本蘸泻。

返回值
URIstring 的副本,其中的某些字符將被十六進(jìn)制的轉(zhuǎn)義序列進(jìn)行替換嘲玫。

說明
該方法不會(huì)對(duì) ASCII 字母和數(shù)字進(jìn)行編碼悦施,也不會(huì)對(duì)這些 ASCII 標(biāo)點(diǎn)符號(hào)進(jìn)行編碼: - _ . ! ~ * ' ( ) 。

其他字符(比如 :;/?:@&=+$,# 這些用于分隔 URI 組件的標(biāo)點(diǎn)符號(hào))去团,都是由一個(gè)或多個(gè)十六進(jìn)制的轉(zhuǎn)義序列替換的抡诞。

提示和注釋
提示:請(qǐng)注意 encodeURIComponent() 函數(shù) 與 encodeURI() 函數(shù)的區(qū)別之處,前者假定它的參數(shù)是 URI 的一部分(比如協(xié)議土陪、主機(jī)名昼汗、路徑或查詢字符串)。因此 encodeURIComponent() 函數(shù)將轉(zhuǎn)義用于分隔 URI 各個(gè)部分的標(biāo)點(diǎn)符號(hào)鬼雀。

4 總結(jié):

通過對(duì)三個(gè)函數(shù)的分析顷窒,我們可以知道:escape()除了 ASCII 字母、數(shù)字和特定的符號(hào)外源哩,對(duì)傳進(jìn)來的字符串全部進(jìn)行轉(zhuǎn)義編碼鞋吉,因此如果想對(duì)URL編碼,最好不要使用此方法励烦。而encodeURI() 用于編碼整個(gè)URI,因?yàn)閁RI中的合法字符都不會(huì)被編碼轉(zhuǎn)換谓着。encodeURIComponent方法在編碼單個(gè)URIComponent(指請(qǐng)求參數(shù))應(yīng)當(dāng)是最常用的,它可以講參數(shù)中的中文坛掠、特殊字符進(jìn)行轉(zhuǎn)義赊锚,而不會(huì)影響整個(gè)URL治筒。

1、 傳遞參數(shù)時(shí)需要使用encodeURIComponent舷蒲,這樣組合的url才不會(huì)被#等特殊字符截?cái)唷?br> 例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7&u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a>');</script>

2矢炼、 進(jìn)行url跳轉(zhuǎn)時(shí)可以整體使用encodeURI

例如:Location.href=encodeURI("http://cang.baidu.com/do/s?word=百度&ct=21");

3、 js使用數(shù)據(jù)時(shí)可以使用escape

例如:搜藏中history紀(jì)錄阿纤。

4句灌、 escape對(duì)0-255以外的unicode值進(jìn)行編碼時(shí)輸出%u****格式,其它情況下escape欠拾,encodeURI胰锌,encodeURIComponent編碼結(jié)果相同。
最多使用的應(yīng)為encodeURIComponent藐窄,它是將中文资昧、韓文等特殊字符轉(zhuǎn)換成utf-8格式的url編碼,所以如果給后臺(tái)傳遞參數(shù)需要使用encodeURIComponent時(shí)需要后臺(tái)解碼對(duì)utf-8支持(form中的編碼方式和當(dāng)前頁面編碼方式相同)

escape不編碼字符有69個(gè):*荆忍,+格带,-,.刹枉,/叽唱,@,_微宝,0-9棺亭,a-z,A-Z

encodeURI不編碼字符有82個(gè):!蟋软,#镶摘,$,&岳守,'凄敢,(,)湿痢,*涝缝,+,,蒙袍,-俊卤,.,/害幅,:消恍,;,=以现,?狠怨,@约啊,_,~佣赖,0-9恰矩,a-z,A-Z

encodeURIComponent不編碼字符有71個(gè):!憎蛤, '外傅,(,)俩檬,*萎胰,-,.棚辽,_技竟,~,0-9屈藐,a-z榔组,A-Z

示例(摘自W3School):

1 escape()

<script type="text/javascript">

document.write(escape("Visit W3School!") + "<br />")
document.write(escape("?!=()#%&"))

</script>

輸出結(jié)果:

Visit%20W3School%21
%3F%21%3D%28%29%23%25%26

2 encodeURI()

<html>
<body>

<script type="text/javascript">

document.write(encodeURI("http://www.w3school.com.cn")+ "<br />")
document.write(encodeURI("http://www.w3school.com.cn/My first/")+ "<br />")
document.write(encodeURI(",/?:@&=+$#"))

</script>

</body>
</html>

輸出結(jié)果:

http://www.w3school.com.cn
http://www.w3school.com.cn/My%20first/
,/?:@&=+$#

對(duì)整個(gè)URL進(jìn)行編碼,而URL的特定標(biāo)識(shí)符不會(huì)被轉(zhuǎn)碼联逻。

3 encodeURIComponent()

例1:

<script type="text/javascript">

document.write(encodeURIComponent("http://www.w3school.com.cn"))
document.write("<br />")
document.write(encodeURIComponent("http://www.w3school.com.cn/p 1/"))
document.write("<br />")
document.write(encodeURIComponent(",/?:@&=+$#"))

</script>

輸出結(jié)果:

http%3A%2F%2Fwww.w3school.com.cn
http%3A%2F%2Fwww.w3school.com.cn%2Fp%201%2F
%2C%2F%3F%3A%40%26%3D%2B%24%23

對(duì)URL中的參數(shù)進(jìn)行編碼搓扯,因?yàn)閰?shù)也是一個(gè)URL,如果不編碼會(huì)影響整個(gè)URL的跳轉(zhuǎn)遣妥。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末擅编,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子箫踩,更是在濱河造成了極大的恐慌,老刑警劉巖谭贪,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件境钟,死亡現(xiàn)場離奇詭異,居然都是意外死亡俭识,警方通過查閱死者的電腦和手機(jī)慨削,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來套媚,“玉大人缚态,你說我怎么就攤上這事〉塘觯” “怎么了玫芦?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長本辐。 經(jīng)常有香客問我桥帆,道長医增,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任老虫,我火速辦了婚禮叶骨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘祈匙。我一直安慰自己忽刽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布夺欲。 她就那樣靜靜地躺著缔恳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪洁闰。 梳的紋絲不亂的頭發(fā)上歉甚,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音扑眉,去河邊找鬼纸泄。 笑死,一個(gè)胖子當(dāng)著我的面吹牛腰素,可吹牛的內(nèi)容都是我干的聘裁。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼弓千,長吁一口氣:“原來是場噩夢啊……” “哼衡便!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起洋访,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤镣陕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后姻政,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體呆抑,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年汁展,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鹊碍。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡食绿,死狀恐怖侈咕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情器紧,我是刑警寧澤耀销,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布逛钻,位于F島的核電站泳挥,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜制肮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一佩捞、第九天 我趴在偏房一處隱蔽的房頂上張望拢肆。 院中可真熱鬧屋谭,春花似錦、人聲如沸转晰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽查邢。三九已至蔗崎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間扰藕,已是汗流浹背缓苛。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留邓深,地道東北人未桥。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像芥备,于是被迫代替她去往敵國和親冬耿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容