| 用 JavaScript 操作字符串 | ||
| 作者: builder 2005-07-08 03:59 PM | ||
雖然 JavaScript 有很多用處,但是處理字符串是其中最流行的一個(gè)。下面讓我們深入地分析一下使用 JavaScript 操作字符串。在 JavaScript 中, String 是對象。 String 對象并不是以字符數組的方式存儲的,所以我們必須使用內建函數來(lái)操縱它們的值。這些內建函數提供了不同的方法來(lái)訪(fǎng)問(wèn)字符串變量的內容。下面我們詳細看一下這些函數。 包羅萬(wàn)象 操作字符串的值是一般的開(kāi)發(fā)人員必須面臨的家常便飯。操作字符串的具體方式有很多,比如說(shuō)從一個(gè)字符串是提取出一部分內容來(lái),或者確定一個(gè)字符串是否包含一個(gè)特定的字符。下面的 JavaScript 函數為開(kāi)發(fā)人員提供了他們所需要的所有功能: • concat() – 將兩個(gè)或多個(gè)字符的文本組合起來(lái),返回一個(gè)新的字符串。 • indexOf() – 返回字符串中一個(gè)子串第一處出現的索引。如果沒(méi)有匹配項,返回 -1 。 • charAT() – 返回指定位置的字符。 • lastIndexOf() – 返回字符串中一個(gè)子串最后一處出現的索引,如果沒(méi)有匹配項,返回 -1 。
• match() – 檢查一個(gè)字符串是否匹配一個(gè)正則表達式。 • substring() – 返回字符串的一個(gè)子串。傳入參數是起始位置和結束位置。 • replace() – 用來(lái)查找匹配一個(gè)正則表達式的字符串,然后使用新字符串代替匹配的字符串。 • search() – 執行一個(gè)正則表達式匹配查找。如果查找成功,返回字符串中匹配的索引值。否則返回 -1 。 • slice() – 提取字符串的一部分,并返回一個(gè)新字符串。 • split() – 通過(guò)將字符串劃分成子串,將一個(gè)字符串做成一個(gè)字符串數組。 • length() – 返回字符串的長(cháng)度,所謂字符串的長(cháng)度是指其包含的字符的個(gè)數。 • toLowerCase() – 將整個(gè)字符串轉成小寫(xiě)字母。 • toUpperCase() – 將整個(gè)字符串轉成大寫(xiě)字母。 注意: concat 、 match 、 replace 和 search 函數是在 JavaScript 1.2 中加入的。所有其它函數在 JavaScript 1.0 就已經(jīng)提供了。 下面讓我們看一下如何在 JavaScript 使用這些函數。下面的代碼是用到了前面提到的所有函數: function manipulateString(passedString1, passedString2) { var concatString; // The string passed to concat is added to the end of the first string concatString = passedString1.concat(passedString2); alert(concatString); // The following if statement will be true since first word is Tony if (concatString.charAt(3) == "y") { alert("Character found!"); } // The last position of the letter n is 10 alert("The last index of n is: " + concatString.lastIndexOf("n")); // A regular expression is used to locate and replace the substring var newString = concatString.replace(/Tony/gi,"General"); // The following yields Please salute General Patton alert("Please salute " + newString); // The match function returns an array containing all matches found matchArray = concatString.match(/Tony/gi); for (var i=0; i<matchArray.length;i++) { alert("Match found: " + matchArray[i]); } // Determine if the regular expression is found, a –1 indicates no if (newString.search(/Tony/) == -1) { alert("String not found"); } else { alert("String found."); } // Extract a portion of the string and store it in a new variable var sliceString = newString.slice(newString.indexOf("l")+2,newString.length); alert(sliceString); // The split function creates a new array containing each value separated by a space stringArray = concatString.split(" "); for (var i=0; i<stringArray.length;i++) { alert(stringArray[i]; } alert(newString.toUpperCase()); alert(newString.toLowerCase()); } 下面是執行上面的代碼得到的結果: Tony Patton 示例代碼把所有這些提到的函數都用到了。 特殊字符 除了這些函數之外,還有很多的特殊字符可以用來(lái)表示關(guān)鍵的效果。這些特殊字符包括: • \t – 跳格鍵 • \b – 退格 / 刪除 • \r – 回車(chē) • \n – 換行 • \f – 換頁(yè) 特殊字符最常見(jiàn)的用途就是格式化輸出。例如,你可能需要在輸出中插入一個(gè)換行來(lái)正確地顯示一個(gè)值。而且,在換行時(shí)也需要回車(chē)。在一些平臺上,“ \n ”已經(jīng)足夠產(chǎn)生換行效果了,而在一些機器上要正確地顯示一個(gè)換行則需要“ \r\n ”。下面的例子顯示了在一個(gè)多行窗口上顯示的特殊字符: var output = null; 前面的例子使用加號來(lái)連接字符串,而沒(méi)有使用 concat 函數。原因很簡(jiǎn)單,對于 concat 函數來(lái)說(shuō),每一個(gè)操作都需要一個(gè)新的變量;反之,我們這里用的這種方法則簡(jiǎn)單地擴展了原有的值,而不需要新的變量。而且,示例中使用換碼符來(lái)正確地顯示特殊字符。系統將一個(gè)反斜線(xiàn)當作一個(gè)信號,認為它后面會(huì )跟一個(gè)特殊字符,但是連著(zhù)兩個(gè)反斜線(xiàn)則抵消這種操作。輸出中的每個(gè)字符都通過(guò) newline 特殊字符被顯示在新的一行。 添加到工具箱中 特殊字符和函數可以與其它 JavaScript 技巧結合起來(lái)解決很多問(wèn)題。其中一種情況是用來(lái)進(jìn)行 JavaScript 客戶(hù)端表單驗證,這篇文章中提出的方法可以簡(jiǎn)單地用來(lái)實(shí)現表單驗證。 下面的代碼將在一個(gè)表單被提交時(shí)調用。要提交的表單包含三個(gè)域:名稱(chēng)、地址和郵政編碼。為了實(shí)現起來(lái)比較簡(jiǎn)單,我們只驗證每個(gè)域都不能為空,并且郵政編碼必須是數字。下面的 JavaScript 代碼完成這一功能: function validation() { var doc = document.forms[0]; var msg = ""; if (doc.Name.value == "") { msg += "- Name is missing\n"; } if (doc.Address.value == "") { msg += "- Address is missing\n"; } if (doc.ZipCode.value == "") { msg += "- Zip code is missing\n"; } var zip = new String(doc.ZipCode.value); if (zip.search(/^[0-9][0-9][0-9][0-9][0-9]$/)==-1) { msg += "- Enter valid Zip code"; } if (msg == "") { doc.submit; } else { msg = "Please correct the following validation errors and re-submit:\n\n" + msg; alert(msg); } } 在用戶(hù)提交表單時(shí),這個(gè)函數就會(huì )被調用。對函數的調用是在一個(gè) HTML 按鈕的 onSubmit 事件中實(shí)現的。 <input type="button" type="submit" value="submit" onClick="validation()"> 驗證函數檢查每個(gè)域是否為空。如果發(fā)現了一個(gè)空值,那么就會(huì )在驗證消息變量 msg 后面添加一個(gè)出錯消息。此外,還使用了一個(gè)正則表達式來(lái)驗證郵政編碼域的格式。在這里,我們只接受五位數的美國地區郵政編碼。如果發(fā)現有任何錯誤(即 msg 變量不為空),那么程序就會(huì )顯示一個(gè)錯誤消息;否則的話(huà),程序就會(huì )提交表單。 一門(mén)強大的語(yǔ)言 JavaScript 已經(jīng)發(fā)展成熟為一種功能完備的語(yǔ)言,能夠用來(lái)構建強大的應用程序。它是對具有非連接性天性的 Web 界面的一個(gè)完美的補充,能夠在不與 Web 服務(wù)器交互的情況下完成很多客戶(hù)端操作。 |
聯(lián)系客服