JavaScript中的16進位字元(改進)

來源:互聯網
上載者:User

原始的代碼: 複製代碼 代碼如下://將文字轉換為16進位
function textToSix(str) {
return escape(str).replace(/%/g, function () {
return "\\";
}).toLowerCase();
}

改進後的: 複製代碼 代碼如下://將文字轉換為16進位
function textToHex(str) {
//escape對0-255以外的unicode值進行編碼時輸出%u****格式,例如:%u6267%u624b%u6cea%u773c
//將其中的%替換成\就是十六進位的
if (typeof str == "string") {
return escape(str).replace(/%/g, function () {
return "\\";
}).toLowerCase();
} else {
return null;
}
}

主要是增加了一個驗證是否為字串的驗證。

在完善了這個方法之後,我又覺得是不是要改進下面這個方法: 複製代碼 代碼如下://將16進位表示為文字
function sixToText(str) {
return unescape(str);
}

本意是將"\unnn"之類的字元轉換迴文字。其實,只需看看unescape這個方法的原理(工作原理:通過找到形式為 %xx 和 %uxxxx 的字元序列(x 表示十六進位的數字),用 Unicode 字元 \u00xx 和 \uxxxx 替換這樣的字元序列進行解碼。來自百度百科的解釋)。就會知道我完全是多此一舉。因為瀏覽器是可以解析十六進位的字元的。例如:

在IE9中:

在Chrome中:

再補充另外一點收穫吧。其實在做這個解析被我替換後的字元時,我最初的想法是將"\"這個字元在替換回"%",然後再用unescape這個解碼函數來解析字元。然而,當我在我想將"\"替換為"%"卻發現了下面的一個比較有意思的現象:像“\”這個字元如果後面沒有碰到“t”,"n"之類可以和t結合在一起組成轉意字元的話,是會被瀏覽器忽略的。用實驗來驗證我的結論吧:

在IE9中調試:

在Chrome下調試:

在這裡定義了一個變數,變數中含有一些平時可能很少出現的字元"\",調試的時候,看看上面的提示了嗎,瀏覽器很智能的忽略掉了特殊位置的字元。因此在將一些看似很平常的字元(例如檔案路徑等)放在js的變數中,可能輸出來的結果並不是預期的。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.