DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript中的字符串操作
JavaScript中的字符串操作
編輯:關於JavaScript     

一、概述
    字符串在javascript中幾乎無處不在,在你處理用戶的輸入數據的時候,在讀取或設置DOM對象的屬性時,在操作cookie時,當然還有更多...。JavaScript的核心部分提供了一組屬性和方法用於通用的字符串操作,如分割字符串,改變字符串的大小寫,操作子字符串等。
    當前的大部分浏覽器也能從強大的正則表達式獲益,因為它極大地簡化了大量的字符串操作任務,不過它也需要你克服一條有些陡峭的學習曲線。在這裡,主要是介紹字符串本身的一些操作,正則表達式會在以後的隨筆中涉及。

二、字符串的創建
    創建一個字符串有幾種方法。最簡單的是用引號將一組字符包含起來,可以將其賦值給一個字符串變量。
    var myStr = "Hello, String!";
    可以用雙引號或單引號將字符串包含,但要注意,作為界定字符串的一對引號必須是相同的,不能混用。
    像var myString = "Fluffy is a pretty cat.'; 這樣的聲明就是非法的。
    允許使用兩種引號,使得某些操作變得簡單,比如將一種嵌入另外一種:
    document.write("<img src='/images/NullPic.gif' height='30' width='100' alt='Logo'>");

    我們在上面腳本創建了幾個字符串,但本質上,它們並不是真正的字符串對象,准確地說,它們是字符串類型的值。要創建一個字符串對象,可使用如下語句:var strObj = new String("Hello, String!");
    使用typeof運算符查看會發現,上面的myStr類型為string,而strObj類型為object。
   
    如果想知道字符串的長度,使用其length屬性:string.length。
    得到字符串的指定位置的字符使用方法:string.charAt(index);

三、字符串的拼接
問題:
    將兩個或多個字符串拼接為一個大的字符串
解決方案:
    非常簡單,就用一個"+"將兩個字符串"相加":
    var longString = "One piece " + "plus one more piece.";
    要將多個字符串累積為一個字符串,還可以使用"+="操作符:
    var result = "";
    result += "My name is Anders"
    result += " and my age is 25";  
   
    要在字符串中添加換行符,需要使用轉義字符"\n":
    var confirmString = "You did not enter a response to the last " +
        "question.\n\nSubmit form anyway?";
    var confirmValue = confirm(confirmString);
    但這種方法只能用在像警告、確認對話框之類的情況下,如果將這段文本作為HTML內容呈現,就無效了,此時用"<br>"代替它:
    var htmlString = "First line of string.<br>Second line of string.";
    document.write(htmlString);

    String對象還提供了方法concat(),它完成與"+"相同的功能:
    string.concat(value1, value2, ...)
    不過concat()方法顯然不如"+"來得直觀簡潔。

四、訪問字符串的子串
問題:
    獲得一字符串的一部分的副本。
解決方案:
    使用substring()或slice()方法(NN4+, IE4+),下面說明它們的具體用法。
    substring()的原型為:  string.substring(from, to)
    第一個參數from指定了子字符串在原字符串中的起始位置(基於0的索引);第二個參數to是可選的,它指定了子字符串在原字符串的結束位置(基於0的索引),一般情況下,它應比from大,如果它被省略,那麼子字符串將一直到原字符串的結尾處。
    如果參數from不小心比參數to大了會怎樣?JavaScript會自動調解子字符串的起止位置,也就是說,substring()總是從兩個參數中較小的那個開始,到較大的那個結束。不過要注意,它包含起始位置的那個字符,但不包含結束位置的那個字符。
    var fullString = "Every dog has his day.";
    var section = fullString.substring(0, 4); // section is "Ever".
    section = fullString.substring(4, 0);     // section

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