[JavaScript] (Day-03) - 字符串

There are no regrets in life, just lessons. 人生中沒有后悔,只有教訓。

JavaScript 的字符串就是用''""括起來的字符表示。

如果'本身也是一個字符,那就可以用""括起來,比如"I'm OK"包含的字符是I'm空格OK 這6個字符。

如果字符串內部既包含'又包含"怎么辦?可以用轉義字符\來標識
比如:

"I\'m \"OK\"!"; // I'm "OK"!

轉義字符\可以轉義很多字符,比如\n表示換行,\t表示制表符,字符\本身也要轉義,所以\\表示的字符就是\


多行字符串

由于多行字符串用\n寫起來比較費事,所以最新的ES6標準新增了一種多行字符串的表示方法,用反引號 `...` 表示:

var multiLine =`這是一個
多行
字符串`;


模板字符串

要把多個字符串連接起來,可以用+號連接:

var name = "Vivian";
var age = 21;
var message = "你好, ' + name + ', 你今年' + age + '歲了!"; 
// 輸出: 你好, Vivian, 你今年21歲了!

如果有很多變量需要連接,用+號就比較麻煩。ES6新增了一種模板字符串,表示方法和上面的多行字符串一樣,但是它會自動替換字符串中的變量:

var name = 'Eric';
var age = 23;
var message = `你好, ${name}, 你今年${age}歲了!`;
// 輸出: 你好, Eric, 你今年23歲了!

操作字符串

獲取字符串長度

var s = "Hello world!";
s.length; // 13

獲取字符串某個位置的字符

要獲取字符串某個指定位置的字符,使用類似Array的下標操作,索引號從0開始

var s = "Hello, world!";

s[0]; //  "H"
s[6]; //  ""
s[7]; //  "w"
s[12]; // "!""
s[13]; // 超出邊界,不會報錯,但一律返回undefined

需要特別注意的是,字符串是不可變的,如果對字符串的某個索引賦值,不會有任何錯誤,但是,也沒有任何效果:

var s = "Owen";
s[0] = "X";
alert(s); // s仍然為'Owen'

JavaScript為字符串提供了一些常用方法,注意,調用這些方法本身不會改變原有字符串的內容,而是返回一個新字符串


toUpperCase

toUpperCase() 把一個字符串全部變為大寫:

var s = "Hello";
s.toUpperCase(); // 返回"HELLO"

toLowerCase

toLowerCase() 把一個字符串全部變為小寫:

var s = "Hello";
var lower = s.toLowerCase(); // 返回"hello",并賦值給變量lower

indexOf

indexOf() 會搜索指定字符串出現的位置:

var s = "hello, world";
s.indexOf("world"); // 返回7
s.indexOf("World"); // 沒有找到指定的子串,返回-1

substring

截取字符串

var s = "hello, world"
s.substring(0, 5); // 從索引0開始到5(不包括5),返回 "hello"
s.substring(7); // 從索引7開始到結束,返回 "world"
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容