<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    本站不再更新,歡迎光臨 java開(kāi)發(fā)技術(shù)網(wǎng)
    隨筆-230  評(píng)論-230  文章-8  trackbacks-0

    JavaScript 操作字符串

    雖然 JavaScript 有很多用處,但是處理字符串是其中最流行的一個(gè)。下面讓我們深入地分析一下使用 JavaScript 操作字符串。在 JavaScript 中, String 是對(duì)象。 String 對(duì)象并不是以字符數(shù)組的方式存儲(chǔ)的,所以我們必須使用內(nèi)建函數(shù)來(lái)操縱它們的值。這些內(nèi)建函數(shù)提供了不同的方法來(lái)訪問(wèn)字符串變量的內(nèi)容。下面我們?cè)敿?xì)看一下這些函數(shù)。

    包羅萬(wàn)象

    操作字符串的值是一般的開(kāi)發(fā)人員必須面臨的家常便飯。操作字符串的具體方式有很多,比如說(shuō)從一個(gè)字符串是提取出一部分內(nèi)容來(lái),或者確定一個(gè)字符串是否包含一個(gè)特定的字符。下面的 JavaScript 函數(shù)為開(kāi)發(fā)人員提供了他們所需要的所有功能:

    ?  concat() – 將兩個(gè)或多個(gè)字符的文本組合起來(lái),返回一個(gè)新的字符串。

    ?  indexOf() – 返回字符串中一個(gè)子串第一處出現(xiàn)的索引。如果沒(méi)有匹配項(xiàng),返回 -1 。

    ?  charAT() – 返回指定位置的字符。

    ?  lastIndexOf() – 返回字符串中一個(gè)子串最后一處出現(xiàn)的索引,如果沒(méi)有匹配項(xiàng),返回 -1 。

    <a target="_blank"><IMG SRC="http://m2.cn.doubleclick.net/123456/banner.gif" WIDTH=468 HEIGHT=60 BORDER=0 ></a>

    ?  match() – 檢查一個(gè)字符串是否匹配一個(gè)正則表達(dá)式。

    ?  substring() – 返回字符串的一個(gè)子串。傳入?yún)?shù)是起始位置和結(jié)束位置。

    ?  replace() – 用來(lái)查找匹配一個(gè)正則表達(dá)式的字符串,然后使用新字符串代替匹配的字符串。

    ?  search() – 執(zhí)行一個(gè)正則表達(dá)式匹配查找。如果查找成功,返回字符串中匹配的索引值。否則返回 -1 。

    ?  slice() – 提取字符串的一部分,并返回一個(gè)新字符串。

    ?  split() – 通過(guò)將字符串劃分成子串,將一個(gè)字符串做成一個(gè)字符串?dāng)?shù)組。

    ?  length() – 返回字符串的長(zhǎng)度,所謂字符串的長(zhǎng)度是指其包含的字符的個(gè)數(shù)。

    ?  toLowerCase() – 將整個(gè)字符串轉(zhuǎn)成小寫字母。

    ?  toUpperCase() – 將整個(gè)字符串轉(zhuǎn)成大寫字母。

    注意: concat 、 match 、 replace 和 search 函數(shù)是在 JavaScript 1.2 中加入的。所有其它函數(shù)在 JavaScript 1.0 就已經(jīng)提供了。

    下面讓我們看一下如何在 JavaScript 使用這些函數(shù)。下面的代碼是用到了前面提到的所有函數(shù):

    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());

    }

    下面是執(zhí)行上面的代碼得到的結(jié)果:

    Tony Patton
    Character Found!
    The last index of n is: 10
    Match found: Tony
    Please salute General Patton
    String not found
    Patton
    Tony
    Patton
    GENERAL PATTON
    general patton

    示例代碼把所有這些提到的函數(shù)都用到了。

    特殊字符

    除了這些函數(shù)之外,還有很多的特殊字符可以用來(lái)表示關(guān)鍵的效果。這些特殊字符包括:

    ?  \t – 跳格鍵

    ?  \b – 退格 / 刪除

    ?  \r – 回車

    ?  \n – 換行

    ?  \f – 換頁(yè)

    特殊字符最常見(jiàn)的用途就是格式化輸出。例如,你可能需要在輸出中插入一個(gè)換行來(lái)正確地顯示一個(gè)值。而且,在換行時(shí)也需要回車。在一些平臺(tái)上,“ \n ”已經(jīng)足夠產(chǎn)生換行效果了,而在一些機(jī)器上要正確地顯示一個(gè)換行則需要“ \r\n ”。下面的例子顯示了在一個(gè)多行窗口上顯示的特殊字符:

    var output = null;
    output = "Special Characters";
    output += "\n";
    output += "===============";
    output += "\n";
    output += "\\t - tab";
    output += "\n";
    output += "\\b - backspace/delete";
    output += "\n";
    output += "\\r - carriage return";
    output += "\n";
    output += "\\n - newline";
    output += "\n";
    output += "\\f - form feed";
    output += "\n";
    alert(output);

    前面的例子使用加號(hào)來(lái)連接字符串,而沒(méi)有使用 concat 函數(shù)。原因很簡(jiǎn)單,對(duì)于 concat 函數(shù)來(lái)說(shuō),每一個(gè)操作都需要一個(gè)新的變量;反之,我們這里用的這種方法則簡(jiǎn)單地?cái)U(kuò)展了原有的值,而不需要新的變量。而且,示例中使用換碼符來(lái)正確地顯示特殊字符。系統(tǒng)將一個(gè)反斜線當(dāng)作一個(gè)信號(hào),認(rèn)為它后面會(huì)跟一個(gè)特殊字符,但是連著兩個(gè)反斜線則抵消這種操作。輸出中的每個(gè)字符都通過(guò) newline 特殊字符被顯示在新的一行。

    添加到工具箱中

    特殊字符和函數(shù)可以與其它 JavaScript 技巧結(jié)合起來(lái)解決很多問(wèn)題。其中一種情況是用來(lái)進(jìn)行 JavaScript 客戶端表單驗(yàn)證,這篇文章中提出的方法可以簡(jiǎn)單地用來(lái)實(shí)現(xiàn)表單驗(yàn)證。

    下面的代碼將在一個(gè)表單被提交時(shí)調(diào)用。要提交的表單包含三個(gè)域:名稱、地址和郵政編碼。為了實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,我們只驗(yàn)證每個(gè)域都不能為空,并且郵政編碼必須是數(shù)字。下面的 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);

    }

    }

    在用戶提交表單時(shí),這個(gè)函數(shù)就會(huì)被調(diào)用。對(duì)函數(shù)的調(diào)用是在一個(gè) HTML 按鈕的 onSubmit 事件中實(shí)現(xiàn)的。

    <input type="button" type="submit" value="submit" onClick="validation()">

    驗(yàn)證函數(shù)檢查每個(gè)域是否為空。如果發(fā)現(xiàn)了一個(gè)空值,那么就會(huì)在驗(yàn)證消息變量 msg 后面添加一個(gè)出錯(cuò)消息。此外,還使用了一個(gè)正則表達(dá)式來(lái)驗(yàn)證郵政編碼域的格式。在這里,我們只接受五位數(shù)的美國(guó)地區(qū)郵政編碼。如果發(fā)現(xiàn)有任何錯(cuò)誤(即 msg 變量不為空),那么程序就會(huì)顯示一個(gè)錯(cuò)誤消息;否則的話,程序就會(huì)提交表單。

    一門強(qiáng)大的語(yǔ)言

    JavaScript 已經(jīng)發(fā)展成熟為一種功能完備的語(yǔ)言,能夠用來(lái)構(gòu)建強(qiáng)大的應(yīng)用程序。它是對(duì)具有非連接性天性的 Web 界面的一個(gè)完美的補(bǔ)充,能夠在不與 Web 服務(wù)器交互的情況下完成很多客戶端操作。


    posted on 2006-02-23 17:54 有貓相伴的日子 閱讀(1010) 評(píng)論(0)  編輯  收藏 所屬分類: javascirpt
    本站不再更新,歡迎光臨 java開(kāi)發(fā)技術(shù)網(wǎng)
    主站蜘蛛池模板: 久久精品国产亚洲AV麻豆不卡| 国产视频精品免费| 亚洲成a人片在线观看久| 亚洲国产片在线观看| 大地资源网高清在线观看免费| 哒哒哒免费视频观看在线www| 亚洲一区二区三区久久久久| 一级毛片免费毛片一级毛片免费| 免费va在线观看| 久久亚洲中文无码咪咪爱| 99久久免费国产精品特黄| 久久久无码精品亚洲日韩蜜臀浪潮 | 美女视频黄a视频全免费网站色窝 美女被cao网站免费看在线看 | 色片在线免费观看| 亚洲国产综合无码一区| 人禽伦免费交视频播放| 亚洲熟伦熟女新五十路熟妇| 老司机午夜性生免费福利| 免费看香港一级毛片| 亚洲精品成a人在线观看☆| 成人毛片免费观看| 国产天堂亚洲国产碰碰| 亚洲精品视频在线观看你懂的| 成年免费a级毛片| 亚洲尤码不卡AV麻豆| 无码日韩精品一区二区三区免费| 亚洲va在线va天堂va888www| 国产一区二区免费视频| 亚洲综合免费视频| 精品剧情v国产在免费线观看| 亚洲av色香蕉一区二区三区 | 蜜臀98精品国产免费观看| 中文字幕亚洲综合小综合在线| 大学生一级特黄的免费大片视频| 亚洲欧美成aⅴ人在线观看| 国产精品亚洲mnbav网站| 免费A级毛片av无码| 亚洲高清一区二区三区电影| 亚洲色偷偷综合亚洲AV伊人| 免费看黄的成人APP| 亚洲色大成网站WWW国产|