一、三個字符方法
兩個用于訪問字符串中特定字符的方法是:charAt()、charCodeAt()。這兩個方法都接受一個參數,即基于0的字符位置。
兩個方法的區別:charAt() 返回給定位置的那個字符,charCodeAt() 返回給定位置的字符編碼。
第三個訪問字符的方法,方括號?數字索引。但是ES7以及更早版本不支持。
var str = 'hello world!';
str.chatAt(0);? ? // h
str.chatCodeAt(0);? ? // 104
str[0];? ? // h
二、4個字符串操作方法
1、concat():專門用來拼接字符串的方法,返回新的字符串,不改變原值。
var str = '123';
str.concat(4);? ? // 1234
console.log(str);? ? // 123
2、基于子字符串創建新字符串的方法 slice()、substr()和substring()。
接受一個或兩個參數:第一個參數指定子字符串的開始位置,第二個參數表示字符串到哪里結束。 對原來字符串沒有影響。
使用區別一:slice()和substring()的第二個參數指定的是子字符串最后一個字符后面的位置(注意是后面一個位置)。而substr()的第二個參數指定的是返回的字符的個數。
區別二:在傳遞給這些方法的參數是負值時,它們的行為不盡相同。
slice()方法將傳入的負值與字符串的長度相加;substr()方法將第一個參數加上字符串的長度,而將負的第二個參數轉換為0。而substring()將所有負值參數都轉換為0。
三、字符串位置方法
indexOf()、lastIndexOf()
四、trim() 方法
該方法刪除前置和后綴的所有空格,然后返回結果,不影響愿字符串;
五、四個字符串大小寫轉換方法
toLowerCase()、toLocaleLowerCase()、toUpperCase()、toLocaleUpperCase()
toLowerCase()和toUpperCase()是兩個經典的方法,toLocaleLowerCase()和toLocaleUpperCase()是針對特定地區的。
六、四個字符串的模式匹配方法
1、match()方法:本質上與調用 RegExp的 exec()方法相同。只接受一個參數,要么是一個正則表達式,要么是一個 RegExp對象。返回的是一個數組
補充RegExp對象的主要方法:exec()
注意:對于exec(),即使在模式中設置了全局標志(g),它每次也只返回一個匹配項,在不設置全局標志時,在同一個字符串上多次調用exec()將始終返回第一個匹配項的信息。而在設置全局標志時,每次調用exec()都會在字符串中繼續查找新匹配項,直到所搜到字符串末尾為止。還有注意lastIndex屬性的變化情況。在全局模式下,lastIndex屬性在每次調用exec()后都會增加,而在非全局模式則始終不變。
RegExp對象的test()方法:
接受一個字符串參數,模式與該參數匹配返回true,否則返回false。經常被用在if語句中。
2、search()方法:
該方法也是一個參數,與match()方法參數相同。
返回字符串中第一個匹配項的索引。如果沒有找到匹配項,則返回-1。
3、replace()方法
該方法有兩個參數:第一個參數是一個RegExp對象或者一個字符串,第二個參數可以是一個字符串或者函數。如果第一個參數是字符串,那么只會替換第一個子字符串。如果要替換所有的子字符串,就是提供一個正則表達式,而且指定全局(g)標志。
如果第二個參數是函數,在只有一個匹配項時,會向該函數傳遞3個參數:模式的匹配項,模式匹配項在字符串中的位置和原始字符串。如果正則表達式中定義了多個捕獲組,傳遞的參數:模式的匹配項、第一個捕獲組的匹配項、第二個捕獲組的匹配項……,但最后兩個參數還是模式匹配項在字符串中的位置和原始字符串。使用函數作為第二個參數可以實現更為精細的替換操作。
4、split方法
可以基于分隔符將一個字符串分成多個子字符串,并放入數組中。其中分隔符可以是字符串,也可以是RegExp對象。還可以接受第二個參數,用于指定數組的大小,確保返回的數組不會超過既定大小。