DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> JavaScript中判斷兩個字符串是否相等的方法
JavaScript中判斷兩個字符串是否相等的方法
編輯:JavaScript基礎知識     

先將用戶的輸入值全部轉換為大寫(或小寫),然後再行比較:

   var name = document.form1.txtUserName.value.toLowerCase();


   if(name == "urname")


   {


     // statements go here.


   }



      JavaScript有兩種相等運算符。一種是完全向後兼容的,標准的"==",如果兩個操作數類型不一致,它會在某些時候自動對操作數進行類型轉換,考慮下面的賦值語句:

   var strA = "i love you!";


   var strB = new String("i love you!");



      這兩個變量含有相同的字符序列,但數據類型卻不同,前者為string,後者為object,在使用"=="操作符時,JavaScript會嘗試各種求值,以檢測兩者是否會在某種情況下相等。所以下面的表達式結果為true: strA == strB。


      第二種操作符是"嚴格"的"===",它在求值時不會這麼寬容,不會進行類型轉換。所以表達式strA === strB的值為false,雖然兩個變量持有的值相同。


      有時代碼的邏輯要求你判斷兩個值是否不相等,這裡也有兩個選擇:"!="和嚴格的"!==",它們的關系就類似於"=="和"==="。


討論:


      "=="和"!="在求值時會盡可能地尋找值的匹配性,但你可能還是想在比較前進行顯式的類型轉換,以"幫助"它們完成工作。比如,如果想判斷一個用戶的輸入值(字符串)是否等於一個數字,你可以讓"=="幫你完成類型轉換:

   if(document.form1.txtAge.value == someNumericVar) { ... }



      也可以提前轉換:

   if(parseInt(document.form1.txtAge.value) == someNumericVar) { ... }



      如果你比較習慣於強類型的編程語言(比如C#,Java等),那麼這裡你可以延續你的習慣(類型轉換),這樣也會增強程序的可讀性。

 

      有一種情況需要注意,就是計算機的區域設置。如果用"<"和">"來比較字符串,那麼JavaScript把它們作為Unicode來比較,但顯然,人們在浏覽網頁時不會把文本當作Unicode來閱讀:) 比如在西班牙語中,按照傳統的排序,"ch"將作為一個字符排在"c"和"d"之間。localeCompare()提供了一種方式,可以幫助你使用默認區域設置下的字符排序規則。

  var strings; // 要排序的字符串數組,假設已經得到初始化


  strings.sort(function(a,b) { return a.localeCompare(b) }); // 調用sort()方法進行排序

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