DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> JS對字符串編碼的幾種方式使用
JS對字符串編碼的幾種方式使用
編輯:JavaScript綜合知識     

   在客戶端中,要對字符串編碼,可以采用:escape();encodeurl();encodeURIComponent();下面我們就來具體講解下這幾個方法。

  函數 描述

  encodeURI() 把字符串編碼為 URI

  encodeURIComponent() 把字符串編碼為 URI 組件

  escape() 對字符串進行編碼

  上面是查詢來自w3school的資料。那麼三者之間有什麼區別呢,請容我測試測試。

   代碼如下:

  var str = "http://localhost:8080/Product/index?id=123&attr=456&area=中國";

  console.log(encodeURI(str));

  console.log(encodeURIComponent(str));

  console.log(escape(str));

  打印結果如下:

   代碼如下:

  http://localhost:8080/Product/index?id=123&attr=456&area=%E4%B8%AD%E5%9B%BD

  http%3A%2F%2Flocalhost%3A8080%2FProduct%2Findex%3Fid%3D123%26attr%3D456%26area%3D%E4%B8

%AD%E5%9B%BD

  http%3A//localhost%3A8080/Product/index%3Fid%3D123%26attr%3D456%26area%3D%u4E2D%u56FD

  可以看出,

  encodeURI不會對:/?&等uri中起分割作用的字符進行編碼;

  encodeURIComponent則會。

  觀察escape則發現,:?&都被轉碼了,而/沒有,w3school解釋是,escape函數會對ascii碼中字母、數字及符號( * @ - _ + . / )之外的所有字符進行編碼。

  另外,我們可以看出escape對漢字“中國”編碼後結果與前兩者不同。W3SCHOOL也建議不使用該方法,用前兩者代替。

  以上所述就是本文的全部內容了,希望對大家學習javascript能夠有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved