Javascript基礎教程之資料類型 (字串 String),javascript基礎教程

來源:互聯網
上載者:User

Javascript基礎教程之資料類型 (字串 String),javascript基礎教程

一.字串

複製代碼 代碼如下:
var language = "javascript";
var language = 'javascript';

字串可以使用雙引號和單引號,根據個人愛好而定。

字串具有length屬性,可以返回變數中字串的個數。

複製代碼 代碼如下:
var test1 = "teacher" ;
    document.write(test1.length);
//輸出test1的字串個數:7

反之,想擷取指定位置的字元,可以使用charAt()函數(第一個字元為0,第二個字元為1,依次類推)

複製代碼 代碼如下:
 var test1 = "teacher" ;
    document.write(test1.charAt(1));
//運行結果為:e ,

如果想取得變數中的字串,可以採用slice(),substring()或者substr()函數。

其中,substring()和slice()都接受兩個參數

複製代碼 代碼如下:
    var test1 = "teacher" ;
    document.write(test1.substring(1)+"<br>");// 輸出eacher
    document.write(test1.substring(1,4)+"<br>"); //輸出eac
    document.write(test1.slice(1,4)+"<br>"); //輸出eac
    document.write(test1.slice(4)+"<br>"); //輸出her
    document.write(test1 + "<br>");//完整字串

 從以上內容看出,substring()和slice()都不改變字串內容,只返回字串的內容。

substing()和slice()的區別主要是對負數的處理不同。

負數參數對於slice()而言,從字串末尾往前計數,對於substring()來說,則是忽略負數,從0開始處理,並將兩個參數中較小的數字作為起始位,較大的作為結束位。

例如substring(2,-3)等同於substing(2,0),也就是等同於substring(0,2)。

複製代碼 代碼如下:
   var test1 = "teacher" ;
    document.write(test1.substring(2,-3)+"<br>"); //te
    document.write(test1.substring(2,0)+"<br>"); //te
    document.write(test1.substring(0,2)+"<br>"); //te
    document.write(test1.slice(2,-3)+"<br>"); //ac
    document.write(test1 + "<br>"); //teacher

 substring()和substr()的區別,舉例說明。

複製代碼 代碼如下:
    var tt,ss ;
    var s = "hellobeijing";
    tt = s.substring(2,8)+"<br>";
    ss = s.substr(2,8);
    document.write(tt);//輸出:llobeij 輸出下標2到下標8之間的字元
    document.write(ss); //輸出:llobeiji (輸出下標2後的8個字元)

 對於用法,另一博友有更多執行個體(地址)

在搜尋字串上,Javascript提供了indexof()和lastindexof()兩個函數。

複製代碼 代碼如下:
 var s = "woaibeijing";
    dd = s.indexOf("e")+"<br>";//從前往後
    ee = s.indexOf("e",3)+"<br>";//選擇性參數,從第幾個字元往後尋找
    ff = s.lastIndexOf("e")+"<br>";//從後往前
    gg = s.lastIndexOf("e",3)+"<br>"; //選擇性參數,從第幾個字元往前尋找
    hh = s.lastIndexOf("H")+"<br>";
    document.write(dd);
    document.write(ff);
    document.write(ee);
    document.write(gg);
    document.write(hh);

另外,indexof()和lastindexof()的用法推薦查看這篇文章。http://www.bkjia.com/article/44921.htm

JS中的indexOf和lastIndexOf是處理字串的一個非常好用的函數,下面對它們的定義、用法、注意事項以及使用建議分別作介紹。

1、strObj.indexOf(subString[, startIndex])

功能:返回源字串內第一次出現指定子字串的首個字元在源字串中的索引值(源字串內第n個字元的索引值為n-1),是整數。

參數含義:

strObj是源字串,必選項。

subString是在源字串對象中尋找的子字串,必選項。

startIndex是開始索引值,indexOf函數是從源字串的索引值為startIndex的字元(即第startIndex+1個字元)開始尋找,可選項。省略時,從源字串索引值為0的字元(即第1個字元)開始尋找。

執行個體分析:

用法1(不指定startIndex值):var i="huoshandao.com".indexOfOf("a"):則i=5
                                               相當於var i="huoshandao.com".indexOf("a",0)
用法2(指定startIndex值):var i="huoshandao.com".indexOf("a",6):則i=8
提示:可以用alert(i);語句測試結果,以下例子也一樣。

注意事項

1)strObj既可以是字串,也可以是字串變數。
     [例子]
     strObj為字串:var i="huoshandao.com".indexOf("."):
     strObj為字串變數:var str="huoshandao.com";var i=str.indexOf(".");
2)subString不可為空字串,如果為空白字串,傳回值為0,但可以是空格。
     [例子]
     subString為空白字串:var i="huo shan dao".indexOf(""):則i=0
     subString為空白格字串:var i="huo shan dao".indexOf(" "):則i=3
3)第1個字元的startIndex值是0,是最小索引值;第2個字元的startIndex值是1;最後一個字元的startIndex值則是源字串長度減1,是最大索引值。
4)如果沒有找到子字串,則返回 -1。
     [例子]
     var i="huoshandao.com".indexOf("huosan"):則i=-1
5)如果startIndex是負數,則相當於startIndex等於0的情況。如果它大於最大索引值,則相當於startIndex等於最大索引值的情況。
    [例子]
     startIndex為負數: var i="huoshandao.com".indexOf(".",-3);則i=10
                                   與var i="huoshandao.com".indexOf(".",0);結果一樣
     startIndex大於等於字串長度:var i="huoshandao.com_".indexOf("_",16);則i=-1
                                                       與var i="huoshandao.com_".indexOf("_",14);i=14

2、strObj.lastIndexOf(subString[, startIndex])

indexOf 函數是從左向右尋找,但實際應用中我們有時想得到從右向左出現某個字元或字串的首個字元索引值,針對這種情況,JS給出另外一個函數 lastIndexOf來解決這個問題,使用方法和indexOf相似,只是它從右向左尋找而已,具體就不再重複,簡單舉幾個例子,和indexOf作比 較:

例1:var i="huo.shan.dao.com".lastIndexOf(".");則i=12而var i="huo.shan.dao.com".indexOf(".");的i=3
例2:var i="huoshandao.com_".lastIndexOf("_",16);則i=14而var i="huoshandao.com_".indexOf("_",16);則i=-1

3、使用建議

為了避免出乎意料的結果,除非有特殊用途,建議遵循以下原則:

1、startIndex為非負數,並且不大於最大索引值。如果startIndex是變數,要先判斷其值是否在這個範圍內。
2、如果子字串subString是變數的話,要先判斷其是否為空白再使用indexOf或lastIndexOf函數。
3、輸入子字串時要特別注意全形字元和半形字元的區別。
4、注意indexOf和lastIndexOf裡面的大小寫,JS對大小寫非常敏感。建議用Dreamweaver編程,如果函數名大小寫寫錯的話,函數顏色是黑色,寫對的話則會變成另外一種顏色。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.