js對文字進行編碼


js對文字進行編碼涉及3個函數:escape,encodeURI,encodeURIComponent,相應3個解碼函數:unescape,decodeURI,decodeURIComponent

1   傳遞參數時需要使用encodeURIComponent,這樣組合的url才不會被#等特殊字符截斷。                           

例如:<script language="javascript">document.write('<a href="http://passport.baidu.com/?logout&aid=7& u='+encodeURIComponent("http://cang.baidu.com/bruce42")+'">退出</a& gt;');</script>

2   進行url跳轉時可以整體使用encodeURI

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

3   js使用數據時可以使用escape

[Huoho.Com編輯]

例如:搜藏中history紀錄。

4   escape0-255以外的unicode值進行編碼時輸出%u****格式,其它情況下escapeencodeURIencodeURIComponent編碼結果相同。
   最多使用的應為encodeURIComponent,它是將中文、韓文等特殊字符轉換成utf-8格式的url編碼,所以如果給后台傳遞參數需要使用encodeURIComponent時需要后台解碼對utf-8支持(form中的編碼方式和當前頁面編碼方式相同)

escape不編碼字符有69個:*+-./@_0-9a-zA-Z

encodeURI不編碼字符有82個:!#$&'()*+,-./:;=?@_~0-9a-zA-Z

encodeURIComponent不編碼字符有71個:! '()*-._~0-9a-zA-Z

    escape(str) 方法,它用於轉義不能用明文正確發送的任何字符。比如,電話號碼中的空格將被轉換成字符 %20,從而能夠在 URL 中傳遞這些字符

如果需要發送安全信息或 XML,可能要考慮使用 send() 發送內容(本系列的后續文章中將討論安全數據和 XML 消息)。如果不需要通過 send() 傳遞數據,則只要傳遞 null 作為該方法的參數即可。

js中的escape可以加密數據

我在用opener給前以頁面傳值的時候,遇到了數據被過濾的事情,好像是空格還是什么符號


被過濾了,想到了escape,好了,我就加密一下,傳過去再解密


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM