JavaScript中String對(duì)象的方法介紹
1.字符方法
1.1 charAt() 方法,返回字符串中指定位置的字符。
var question = "Do you like JavaScript?"; alert(question.charAt(5)); //"u"
字符串 "Do you like JavaScript?" 的長(zhǎng)度為23,即位置從0到22。指定位置5處的字符是"u"。
1.2 charCodeAt() 方法,返回字符串中指定位置的字符編碼。
var question = "Do you like JavaScript?"; alert(question.charCodeAt(5)); //"117"
位置5處的字符"u"的字符編碼是"117"。
charAt() 和 charCodeAt() 都是針對(duì)單個(gè)字符進(jìn)行操作的方法。
2.字符串操作方法
這個(gè)小節(jié)的字符串操作方法是關(guān)于創(chuàng)建新字符串的方法。這些方法包括 concat()、slice()、substring()、substr()。
concat() 是通過(guò)拼接的方式創(chuàng)建新的字符串,slice()、substring()、substr() 是通過(guò)提取的方式創(chuàng)建新的字符串。
這四種方法不會(huì)改變?cè)甲址?/p>
2.1 concat() 方法,將一個(gè)或多個(gè)字符串拼接起來(lái),返回新的字符串。不改變?cè)甲址?/p>
concat() 方法可以接受一個(gè)或多個(gè)參數(shù)。
concat() 方法接受一個(gè)參數(shù)。
var love = "I love ";
var result = love.concat("you");
alert(result); //"I love you"
alert(love); //"I love "
love 調(diào)用了 concat() 方法,返回 "I love you",love 的值并沒(méi)有改變。
concat() 方法接受多個(gè)參數(shù)。
var love = "I love ";
var result = love.concat("you"," very"," much","!");
alert(result); //"I love you very much!"
alert(love); //"I love "
不過(guò),在實(shí)踐中,通常用 + 號(hào)操作符將字符串拼接在一起。
2.2 slice()、substring()、substr() 方法,通過(guò)提取原始字符串的部分或全部來(lái)創(chuàng)建新的字符串,返回創(chuàng)建后的新字符串,不改變?cè)甲址?/p>
slice()、substring()、substr() 方法可以接受一個(gè)或兩個(gè)參數(shù),這些參數(shù)為數(shù)字,可以是正值參數(shù),也可以是負(fù)值參數(shù)。
2.2.1 參數(shù)為正值時(shí)
傳入兩個(gè)參數(shù)的情況
對(duì)于 slice() 、substring() ,第一個(gè)參數(shù)為提取的開始位置(包括開始位置的字符),第二個(gè)參數(shù)為提取的結(jié)束位置(不包括結(jié)束位置的字符)。
對(duì)于 substr(),第一個(gè)參數(shù)為提取的開始位置(包括開始位置的字符),第二個(gè)參數(shù)為提取的字符個(gè)數(shù)。
var hello = "I love JavaScript!"; alert(hello.slice(7,11)); //"Java" alert(hello.substring(7,11)); //"Java" alert(hello.substr(7,11)); //"JavaScript!"
字符串 "I love JavaScript!" 長(zhǎng)度為18,即位置從0到17。第7位的字符是 "J",第11位的字符是 "S"。
slice()、substring() 提取的子字符串是從第7位開始(包括第7位的 "J")到第11位結(jié)束(不包括第11位的 "S"),于是用這兩個(gè)方法提取的新字符串是 "Java"。而 substr() 則是從第7位 "J" 開始(包括第7位的 "J"),提取11個(gè)字符,最后提取的新字符串為 "JavaScript!"。
傳入一個(gè)參數(shù)的情況
參數(shù)為正值,傳入一個(gè)參數(shù)時(shí),slice()、substring()、substr() 方法提取原理相同,即從參數(shù)的位置開始提?。?span style="color: #ff0000">包括開始位置的字符),一直提取到原始字符串的最后一個(gè)字符(包括最后一個(gè)字符)。
var hello = "I love JavaScript!"; alert(hello.slice(7)); //"JavaScript!" alert(hello.substring(7)); //"JavaScript!" alert(hello.substr(7)); //"JavaScript!"
傳入了一個(gè)參數(shù)7,即從第7位開始(包括第7位的 "J"),一直提取到原始字符串的最后一位(包括最后一位的 "!")。于是,只有一個(gè)參數(shù),且參數(shù)為正值時(shí),slice()、substring()、substr() 方法返回的新字符串相同。
2.2.2 參數(shù)為負(fù)值時(shí),不管是一個(gè)參數(shù)還是兩個(gè)參數(shù)
slice() 方法會(huì)將傳入的所有負(fù)值與字符串長(zhǎng)度相加。
substring() 方法會(huì)將傳入的所有負(fù)值都轉(zhuǎn)化為0。
substr() 方法,若第一個(gè)參數(shù)是負(fù)值,則將負(fù)值與字符串長(zhǎng)度相加;若第二個(gè)參數(shù)是負(fù)值,則將其轉(zhuǎn)化為0。
var hello = "I love JavaScript!"; alert(hello.slice(-11)); //"JavaScript!" alert(hello.substring(-11)); //"I love JavaScript!" alert(hello.substr(-11)); //"JavaScript!" alert(hello.slice(-11,-9)); //"Ja" alert(hello.substring(-11,-9)); //""(空字符串) alert(hello.substr(-11,-9)); //""(空字符串)
當(dāng)傳入一個(gè)負(fù)值參數(shù)-1時(shí),
slice() 將負(fù)值參數(shù)與字符串長(zhǎng)度相加,前面提到過(guò),字符串 "I love JavaScript!" 的長(zhǎng)度為18,于是 slice(-11) 即相當(dāng)于 slice(7),即從第7位開始提取,最后提取的子字符串為 "JavaScript!";
substring() 會(huì)將負(fù)值轉(zhuǎn)化為0,substring(-11) 相當(dāng)于 substring(0),即從第0位開始提取,最后提取的子字符串為 "I love JavaScript!";
substr() 將負(fù)值參數(shù)與字符串長(zhǎng)度相加,substr(-11) 相當(dāng)于 substr(7),即從第7位開始提取,最后提取的子字符串為 "JavaScript!"。
當(dāng)傳入?yún)?shù)-11,-9時(shí),
slice() 將所有負(fù)值參數(shù)與字符串長(zhǎng)度相加,slice(-11,-9) 相當(dāng)于 slice(7,9),最后提取的子字符串為 "Ja";
substring() 會(huì)將所有負(fù)值轉(zhuǎn)化為0,substring(-11,-9) 相當(dāng)于 substring(0,0),即從第0位開始,第0位結(jié)束,即提取的是空字符串;
substr() 將第一個(gè)參數(shù)-11與字符串長(zhǎng)度相加,將第二個(gè)參數(shù)-9轉(zhuǎn)化為0,substr(-11,-9) 相當(dāng)于 substr(7,0),即從第7位開始,提取0個(gè)字符串,即也是空字符串。
3.字符串位置方法
indexOf() 方法和 lastIndexOf() 方法,返回要檢索的子字符串在原始字符串中第一次出現(xiàn)的位置。
indexOf() 方法從原始字符串開頭向后檢索子字符串,lastIndexOf() 方法從原始字符串末尾向前檢索子字符串。
indexOf() 方法和 lastIndexOf() 方法接受一個(gè)必選參數(shù)。
var test = "balala balala balala";
alert(test.indexOf("a")); //"1"
alert(test.lastIndexOf("a")); //"19"
indexOf() 從開始位置向后檢索子字符串 "a","a" 第一次出現(xiàn)的位置是1;lastIndexOf() 從末尾位置向前檢索子字符串 "a","a" 第一次出現(xiàn)的位置是19。
如果沒(méi)有找到要檢索的子字符串,則這兩個(gè)方法都會(huì)返回-1。
var test = "balala balala balala";
alert(test.indexOf("h")); //"-1"
alert(test.lastIndexOf("h")); //"-1"
indexOf() 方法和 lastIndexOf() 方法接受第二個(gè)可選參數(shù),表示從原始字符串的哪個(gè)位置開始。
var test = "balala balala balala";
alert(test.indexOf("a",7)); //"8"
alert(test.lastIndexOf("a",7)); //"5"
indexOf("a",7) 從第7位向后檢索子字符串 "a","a" 第一次出現(xiàn)的位置是8;lastIndexOf("a",7) 從第7位向前檢索子字符串 "a","a" 第一次出現(xiàn)的位置是5。
4.字符串大小寫換換方法
ECMAScript 中涉及字符串大小寫轉(zhuǎn)換的方法有4個(gè):toUpperCase()、toLocaleUpperCase()、toLowerCase()、toLocaleLowerCase()。
toUpperCase() 和 toLowerCase() 是典型的方法,toLocaleUpperCase() 和 toLocaleLowerCase() 是針對(duì)當(dāng)?shù)氐貐^(qū)的方法,以保證字符串正確的轉(zhuǎn)換。
在不知道自己的代碼在哪種語(yǔ)言環(huán)境中運(yùn)行時(shí),使用針對(duì)當(dāng)?shù)氐貐^(qū)的方法更穩(wěn)妥一些。
var test = "balala balala balala"; alert(test.toLocaleUpperCase()); //"BALALA BALALA BALALA" alert(test.toUpperCase()); //"BALALA BALALA BALALA" alert(test.toLocaleLowerCase()); //"balala balala balala" alert(test.toLowerCase()); //"balala balala balala"
5.trim()方法
trim() 方法會(huì)創(chuàng)建原始字符串的副本,并刪除前置和后綴的所有空格,然后返回結(jié)果,不會(huì)改變?cè)甲址?/p>
var test = " balala balala balala "; var test1 = test.trim(); alert(test1); //"balala balala balala" alert(test); // " balala balala balala " alert(test1.length); //"20" alert(test.length); //"28"
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
- JavaScript之String常見(jiàn)的方法詳解
- 用jQuery將JavaScript對(duì)象轉(zhuǎn)換為querystring查詢字符串的方法
- JavaScript基于擴(kuò)展String實(shí)現(xiàn)替換字符串中index處字符的方法
- JavaScript中的toString()和toLocaleString()方法的區(qū)別
- javascript中數(shù)組(Array)對(duì)象和字符串(String)對(duì)象的常用方法總結(jié)
- JavaScript獲取URL中參數(shù)querystring的方法詳解
- 梳理總結(jié)JavaScript的23個(gè)String方法
相關(guān)文章
微信小程序?qū)崿F(xiàn)幸運(yùn)大轉(zhuǎn)盤功能的示例代碼
這篇文章主要介紹了如何在微信小程序中實(shí)現(xiàn)幸運(yùn)大轉(zhuǎn)盤功能,參與用戶點(diǎn)擊抽獎(jiǎng)便可抽取輪盤的獎(jiǎng)品,感興趣的小伙伴可以跟隨小編一起動(dòng)手試一試2022-03-03
JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼
這篇文章主要為大家詳細(xì)介紹了JavaScript注冊(cè)時(shí)密碼強(qiáng)度校驗(yàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
微信小程序?qū)崿F(xiàn)元素漸入漸出動(dòng)畫效果封裝方法
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)元素漸入漸出動(dòng)畫效果封裝方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
每天一篇javascript學(xué)習(xí)小結(jié)(String對(duì)象)
這篇文章主要介紹了javascript中的String對(duì)象知識(shí)點(diǎn),對(duì)String對(duì)象的基本使用方法,以及各種方法進(jìn)行整理,感興趣的小伙伴們可以參考一下2015-11-11
Webpack-cli安裝成功后查看webpack -v報(bào)錯(cuò)案例詳解
這篇文章主要介紹了Webpack-cli安裝成功后查看webpack -v報(bào)錯(cuò)案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
js獲取元素的外鏈樣式的簡(jiǎn)單實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇js獲取元素的外鏈樣式的簡(jiǎn)單實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-06-06
js判斷手機(jī)號(hào)是否正確并返回的實(shí)現(xiàn)代碼
這篇文章主要介紹了js判斷手機(jī)號(hào)是否正確并返回的實(shí)現(xiàn)代碼,以及使用正則表達(dá)式判斷手機(jī)號(hào)是否正確,需要的的朋友參考下2017-01-01
javascript 小數(shù)取整簡(jiǎn)單實(shí)現(xiàn)方式
這篇文章主要介紹了javascript 小數(shù)取整d的簡(jiǎn)單實(shí)現(xiàn)方式,需要的朋友可以參考下2014-05-05

