麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 語言 > JavaScript > 正文

深入淺析JavaScript字符串操作方法 slice、substr、substring及其IE兼容性

2024-05-06 16:26:29
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JavaScript字符串操作方法 slice、substr、substring及其IE兼容性 的相關資料,需要的朋友可以參考下
 

在截取字符串時常常會用到substr()、substring()、slice()方法,有時混淆之間的用法,故總結下。

閱讀目錄
•slice()
•substring()
•substr()
•總結  

slice()

定義:接受一個或者兩個參數,第一個參數指定子字符串的開始位置。第二個參數表示子字符串的結束位置(不包括結束位置的那個字符),如果沒有傳遞第二個參數,則將字符串的長度作為結束位置。

1、傳遞參數為正值情況:

var str ="helloWorld";// 一個參數,則將字符串長度作為結束位置alert(str.slice(3)); // "loWorld"// 兩個參數,7位置上的字符為"r",但不包括結束位置的字符alert(str.slice(3,7)); // "loWo" 

2、傳遞參數為負值的情況:

slice()方法會將傳入的負值與字符串長度相加。 var str ="helloWorld";// 一個參數,與字符串長度相加即為slice(7)alert(str.slice(-3)); // "rld"// 兩個參數,與字符串長度相加即為slice(3,6)alert(str.slice(3,-4)); // "loW" 

3、第二個參數比第一個參數值小的情況:

slice()方法傳入的第二個參數比第一個參數小的話,則返回空字符串。

var str ="helloWorld";alert(str.slice(5,3)); // "" 

4、IE兼容性

在IE8瀏覽器測試下,沒啥問題,行為與現代瀏覽器一致。

substring()

定義:接受一個或者兩個參數,第一個參數指定子字符串的開始位置。第二個參數表示子字符串的結束位置(不包括結束位置的那個字符),如果沒有傳遞第二個參數,則將字符串的長度作為結束位置。

1、傳遞參數為正值情況:與slice()方法行為相同的

var str ="helloWorld";// 一個參數,則將字符串長度作為結束位置alert(str.substring(3)); // "loWorld"// 兩個參數,7位置上的字符為"r",但不包括結束位置的字符alert(str.substring(3,7)); // "loWo" 

2、傳遞參數為負值的情況:

substring()方法會把所有負值參數轉換為0。來看下例子:

var str ="helloWorld";// 兩個參數,-4會轉換為0,相當于substring(3,0) -->即為 substring(0,3)alert(str.substring(3,-4)); // "hel" 

substring()方法會將較小的數作為開始位置,將較大的數作為結束位置。如上面的例子substring(3,0) 與substring(0,3)是一樣效果的。

4、IE兼容性

在IE8瀏覽器測試下,沒啥問題,行為與現代瀏覽器一致。

substr()

定義:接受一個或者兩個參數,第一個參數指定子字符串的開始位置。第二個參數跟之前的方法有些區別,表示返回的字符個數。如果沒有傳遞第二個參數,則將字符串的長度作為結束位置。來看例子:

1、傳遞參數為正值情況:

var str ="helloWorld";// 一個參數,則將字符串長度作為結束位置alert(str.substr(3)); // "loWorld"// 兩個參數,從位置3開始截取后面7個字符alert(str.substr(3,7)); // "loWorld" 

2、傳遞參數為負值的情況:

substr()方法會將負的第一個參數加上字符串的長度,而將負的第二個參數轉換為0。

var str ="helloWorld";// 將第一個負的參數加上字符串的長度--->//即為:substr(7,5) ,從位置7開始向后截取5個字符alert(str.substr(-3,5)); // "rld"// 將第二個參數轉換為0// 即為:substr(3,0),即從位置3截取0個字符串,則返回空alert(str.substr(3,-2)); // "" 

3、IE兼容性

substr()方法傳遞負值的情況下會存在問題,會返回原始的字符串。IE9修復了此問題。

總結

在傳遞正值參數情況下,slice() 和 substring () 行為是一致的,substr()方法在第二個參數上會容易混淆

在傳遞負值參數情況下,slice() 方法是通過字符串長度相加,符合一般思維,substring()第二個參數轉換為0會容易出問題,起始位置會容易變更,substr() 方法負值情況下會出現IE兼容性問題。

綜上,小弟一般推薦使用slice()方法。

下面給大家介紹slice,substr和substring的區別

首先,他們都接收兩個參數,slice和substring接收的是起始位置和結束位置(不包括結束位置),而substr接收的則是起始位置和所要返回的字符串長度。直接看下面例子:

 var test = 'hello world';  alert(test.slice(,));    //o w  alert(test.substring(,));   //o w  alert(test.substr(,));   //o world 

這里有個需要注意的地方就是:substring是以兩個參數中較小一個作為起始位置,較大的參數作為結束位置。

如:

alert(test.substring(7,4));   //o w 

接著,當接收的參數是負數時,slice會將它字符串的長度與對應的負數相加,結果作為參數;substr則僅僅是將第一個參數與字符串長度相加后的結果作為第一個參數;substring則干脆將負參數都直接轉換為0。測試代碼如下:

var test = 'hello world';  alert(test.slice(-));   //rld  alert(test.substring(-));  //hello world  alert(test.substr(-));  //rld  alert(test.slice(,-));  //lo w  alert(test.substring(,-)); //hel  alert(test.substr(,-));  //空字符串 

 注意:IE對substr接收負值的處理有錯,它會返回原始字符串。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 免费在线观看毛片视频 | 国产影院在线观看 | 国产午夜三级一区二区三桃花影视 | 香蕉久久久精品 | 在线成人一区二区 | 欧美在线观看视频网站 | 国产精品自拍av | 欧美国产一级片 | 主播粉嫩国产在线精品 | 红杏亚洲影院一区二区三区 | 一级黄色毛片a | 国产成人精品一区二区视频免费 | 色污视频在线观看 | 失禁高潮抽搐喷水h | 羞羞视频免费入口网站 | 日本在线播放一区二区 | 日本在线观看视频网站 | 日日操夜夜透 | 久久96国产精品久久秘臀 | av在线免费播放 | 激情视频免费看 | 久久精片 | 午夜久久视频 | 国产精品一区在线看 | 日韩毛片网 | 毛片118极品美女写真 | 免看一级片| 久色伊人 | 午夜精品小视频 | 成人一区久久 | 泰剧19禁啪啪无遮挡大尺度 | 国产色视频免费 | 中文字幕一区久久 | 亚洲精品com| 国内精品伊人久久久久网站 | 国产亚洲精品视频中文字幕 | 福利在线播放 | av电影网站在线 | 精品呦女 | 成人精品久久 | 日韩视频在线不卡 |