javascript截取字符串小結(jié)
來(lái)源:易賢網(wǎng) 閱讀:751 次 日期:2015-04-29 14:52:12
溫馨提示:易賢網(wǎng)小編為您整理了“javascript截取字符串小結(jié)”,方便廣大網(wǎng)友查閱!

本文總結(jié)介紹了三種使用Javascript截取字符串的方法,同時(shí)也總結(jié)了兩種截取中文字符串的辦法,分享一下。

1.substring 方法

定義和用法

substring 方法用于提取字符串中介于兩個(gè)指定下標(biāo)之間的字符。

語(yǔ)法

stringObject.substring(start,stop)

參數(shù) 描述

start 必需。一個(gè)非負(fù)的整數(shù),規(guī)定要提取的子串的第一個(gè)字符在 stringObject 中的位置。

stop 可選。一個(gè)非負(fù)的整數(shù),比要提取的子串的最后一個(gè)字符在 stringObject 中的位置多 1。如果省略該參數(shù),那么返回的子串會(huì)一直到字符串的結(jié)尾。

返回值

一個(gè)新的字符串,該字符串值包含 stringObject 的一個(gè)子字符串,其內(nèi)容是從 start 處到 stop-1 處的所有字符,其長(zhǎng)度為 stop 減 start。

說(shuō)明

substring 方法返回的子串包括 start 處的字符,但不包括 end 處的字符。

如果 start 與 end 相等,那么該方法返回的就是一個(gè)空串(即長(zhǎng)度為 0 的字符串)。

如果 start 比 end 大,那么該方法在提取子串之前會(huì)先交換這兩個(gè)參數(shù)。

如果 start 或 end 為負(fù)數(shù),那么它將被替換為 0。

具體使用案例:

var str = "0123456789"; alert(str.substring(0));------------"0123456789" alert(str.substring(5));------------"56789" alert(str.substring(10));-----------"" alert(str.substring(12));-----------"" alert(str.substring(-5));-----------"0123456789" alert(str.substring(-10));----------"0123456789" alert(str.substring(-12));----------"0123456789" alert(str.substring(0,5));----------"01234" alert(str.substring(0,10));---------"0123456789" alert(str.substring(0,12));---------"0123456789" alert(str.substring(2,0));----------"01" alert(str.substring(2,2));----------"" alert(str.substring(2,5));----------"234" alert(str.substring(2,12));---------"23456789" alert(str.substring(2,-2));---------"01" alert(str.substring(-1,5));---------"01234" alert(str.substring(-1,-5));--------""

2.substr 方法

定義和用法

substr 方法用于返回一個(gè)從指定位置開(kāi)始的指定長(zhǎng)度的子字符串。

語(yǔ)法

stringObject.substr(start [, length ])

參數(shù) 描述

start 必需。所需的子字符串的起始位置。字符串中的第一個(gè)字符的索引為 0。

length 可選。在返回的子字符串中應(yīng)包括的字符個(gè)數(shù)。

說(shuō)明

如果 length 為 0 或負(fù)數(shù),將返回一個(gè)空字符串。

如果沒(méi)有指定該參數(shù),則子字符串將延續(xù)到stringObject的最后。

具體使用案例:

var str = "0123456789"; alert(str.substr(0));---------------"0123456789" alert(str.substr(5));---------------"56789" alert(str.substr(10));--------------"" alert(str.substr(12));--------------"" alert(str.substr(-5));--------------"0123456789" alert(str.substr(-10));-------------"0123456789" alert(str.substr(-12));-------------"0123456789" alert(str.substr(0,5));-------------"01234" alert(str.substr(0,10));------------"0123456789" alert(str.substr(0,12));------------"0123456789" alert(str.substr(2,0));-------------"" alert(str.substr(2,2));-------------"23" alert(str.substr(2,5));-------------"23456" alert(str.substr(2,12));------------"23456789" alert(str.substr(2,-2));------------"" alert(str.substr(-1,5));------------"01234" alert(str.substr(-1,-5));-----------""

3.自定義方法

以上兩種方法只可以對(duì)英文和數(shù)字進(jìn)行截取,遇到中文便無(wú)可奈何了,強(qiáng)制使用會(huì)導(dǎo)致出現(xiàn)亂碼的情況,經(jīng)本人認(rèn)證研究終于總結(jié)出了兩種能夠使用Javascript截取字符串中包含中文的方法:

第一種方法:

String.prototype.sub=function(n){ var r=/[^\x00-\xff]/g; if(this.replace(r,"mm").length<=n){return this;} var m=Math.floor(n/2); for(var i=m;i<this.length;i++){ if(this.substr(0,i).replace(r,"mm").length>=n){ return this.substr(0,i)+"..."; } } return this; }

第二種方法:

//截取字符串 包含中文處理,參數(shù)含義:(字符串,截取長(zhǎng)度,是否增加...)

function subString(str, len, hasDot){ var newLength=0; var newStr=""; var chineseRegex=/[^\x00-\xff]/g; var singleChar=''; var strLength=str.replace(chineseRegex,'**').length; for(var i=0;i < strLength;i++){ singleChar=str.charAt(i).toString(); if(singleChar.match(chineseRegex) != null){ newLength+=2; }else{ newLength++; } if(newLength>len){ break; } newStr+=singleChar; } if(hasDot && strLength>len){ newStr+='...'; } return newStr; }

以上使用Js截取中文字符串的具體使用方法如下:

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>Javascript字符串截取處理總結(jié)(Js截取中文字符串總結(jié))</title> <script language="javascript"> String.prototype.sub=function(n){var r=/[^\x00-\xff]/g;if(this.replace(r,"mm").length<=n){return this}var m=Math.floor(n/2);for(var i=m;i<this.length;i++){if(this.substr(0,i).replace(r,"mm").length>=n){return this.substr(0,i)+"..."}}return this}; function subString(str,len,hasDot){var newLength=0;var newStr="";var chineseRegex=/[^\x00-\xff]/g;var singleChar='';var strstrLength=str.replace(chineseRegex,'**').length;for(var i=0;i<strLength;i++){singleChar=str.charAt(i).toString();if(singleChar.match(chineseRegex)!=null){newLength+=2}else{newLength++}if(newLength>len){break}newStr+=singleChar}if(hasDot&&strLength>len){newStr+='...'}return newStr} </script> </head> <body> <script language="javascript"> var str='我愛(ài); alert(str.sub(10)); alert(subString(str,10,false)); </script> </body> </html>

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看腳本欄目
易賢網(wǎng)手機(jī)網(wǎng)站地址:javascript截取字符串小結(jié)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)