好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > js正則函數(shù)match、exec、test、search、replace、split使用介紹集合

js正則函數(shù)match、exec、test、search、replace、split使用介紹集合

熱門標簽:惠安地圖標注 哈爾濱公司外呼系統(tǒng)代理 山東外呼系統(tǒng)聯(lián)系方式 地圖標注店鋪地圖標注酒店 淄博市張店區(qū)地圖標注 遼寧秒客來電話機器人 浙江營銷外呼系統(tǒng)有哪些 自己做的電銷機器人 上海銷售電銷機器人軟件
match 方法
使用正則表達式模式對字符串執(zhí)行查找,并將包含查找的結(jié)果作為數(shù)組返回。
stringObj.match(rgExp)
參數(shù)
stringObj
必選項。對其進行查找的 String 對象或字符串文字。
rgExp
必選項。為包含正則表達式模式和可用標志的正則表達式對象。也可以是包含正則表達式模式和可用標志的變量名或字符串文字。
其余說明與exec一樣,不同的是如果match的表達式匹配了全局標記g將出現(xiàn)所有匹配項,而不用循環(huán),但所有匹配中不會包含子匹配項。
例子1:
function MatchDemo(){ var r, re; // 聲明變量。 var s = "The rain in Spain falls mainly in the plain"; re = /(a)in/ig; // 創(chuàng)建正則表達式模式。 r = s.match(re); // 嘗試去匹配搜索字符串。 document.write(r); // 返回的數(shù)組包含了所有 "ain" 出現(xiàn)的四個匹配,r[0]、r[1]、r[2]、r[3]。 // 但沒有子匹配項a。}輸出結(jié)果:ain,ain,ain,ain
exec 方法
用正則表達式模式在字符串中查找,并返回該查找結(jié)果的第一個值(數(shù)組),如果匹配失敗,返回null。
rgExp.exec(str)
參數(shù)
rgExp
必選項。包含正則表達式模式和可用標志的正則表達式對象。
str
必選項。要在其中執(zhí)行查找的 String 對象或字符串文字。
返回數(shù)組包含:
input:整個被查找的字符串的值;
index:匹配結(jié)果所在的位置(位);
lastInput:下一次匹配結(jié)果的位置;
arr:結(jié)果值,arr[0]全匹配結(jié)果,arr[1,2...]為表達式內(nèi)()的子匹配,由左至右為1,2...。
例子2:
復制代碼 代碼如下:

function RegExpTest(){
var src="http://sumsung753.blog.163.com/blog/I love you!";
var re = /\w+/g; // 注意g將全文匹配,不加將永遠只返回第一個匹配。
var arr;
while((arr = re.exec(src)) !=null){ //exec使arr返回匹配的第一個,while循環(huán)一次將使re在g作用尋找下一個匹配。
document.write(arr.index + "-" + arr.lastIndex + ":" + arr + "br/>");
for(key in arr){
document.write(key + "=>" + arr[key] + "br/>");
}
document.write("br/>");
}
}
window.onload = RegExpTest();

輸出結(jié)果:
0-1:I //0為index,i所在位置,1為下一個匹配所在位置
input=>I love you!
index=>0
lastIndex=>1
0=>I
2-6:love
input=>I love you!
index=>2
lastIndex=>6
0=>love
7-10:you
input=>I love you!
index=>7
lastIndex=>10
0=>you
說明:根據(jù)手冊,exec只返回匹配結(jié)果的第一個值,比如上例如果不用while循環(huán),將只返回'I'(盡管i空格后的love和you都符合表達式),無論re表達式用不用全局標記g。但是如果為正則表達式設置了全局標記g,exec 從以 lastIndex 的值指示的位置開始查找。如果沒有設置全局標志,exec 忽略 lastIndex 的值,從字符串的起始位置開始搜索。利用這個特點可以反復調(diào)用exec遍歷所有匹配,等價于match具有g標志。
當然,如果正則表達式忘記用g,而又用循環(huán)(比如:while、for等),exec將每次都循環(huán)第一個,造成死循環(huán)。
exec的輸出將包含子匹配項。
例子3:
復制代碼 代碼如下:

function execDemo(){
var r, re; // 聲明變量。
var s = "The rain in Spain falls mainly in the plain";
re = /[\w]*(ai)n/ig;
r = re.exec(s);
document.write(r + "br/>");
for(key in r){
document.write(key + "-" + r[key] + "br/>");
}
}
window.onload = execDemo();

輸出:
rain,ai
input-The rain in Spain falls mainly in the plain
index-4
lastIndex-8
0-rain
1-ai
test 方法
返回一個 Boolean 值,它指出在被查找的字符串中是否匹配給出的正則表達式。
rgexp.test(str)
參數(shù)
rgexp
必選項。包含正則表達式模式或可用標志的正則表達式對象。
str
必選項。要在其上測試查找的字符串。
說明
test 方法檢查字符串是否與給出的正則表達式模式相匹配,如果是則返回 true,否則就返回 false。
例子4:
復制代碼 代碼如下:

function TestDemo(re, s){
var s1;
if (re.test(s))
s1 = " 匹配正則式 ";
else
s1 = " 不匹配正則式 ";
return("'" + s + "'" + s1 + "'"+ re.source + "'");
}
window.onload = document.write(TestDemo(/ab/,'cdef'));

輸出結(jié)果:'cdef' 不匹配正則式 'ab'
注意:test()繼承正則表達式的lastIndex屬性,表達式在匹配全局標志g的時候須注意。
例子5:
復制代碼 代碼如下:

function testDemo(){
var r, re; // 聲明變量。
var s = "I";
re = /I/ig; // 創(chuàng)建正則表達式模式。
document.write(re.test(s) + "br/>"); // 返回 Boolean 結(jié)果。
document.write(re.test(s) + "br/>");
document.write(re.test(s));
}
testDemo();

輸出結(jié)果:
true
false
true
當?shù)诙握{(diào)用test()的時候,lastIndex指向下一次匹配所在位置1,所以第二次匹配不成功,lastIndex重新指向0,等于第三次又重新匹配。下例顯示test的lastIndex屬性:
例子6:
復制代碼 代碼如下:

function testDemo(){
var r, re; // 聲明變量。
var s = "I";
re = /I/ig; // 創(chuàng)建正則表達式模式。
document.write(re.test(s) + "br/>"); // 返回 Boolean 結(jié)果。
document.write(re.lastIndex); // 返回 Boolean 結(jié)果。
}
testDemo();

輸出:
true
1
解決方法:將test()的lastIndex屬性每次重新指向0,re.lastIndex = 0;

search 方法
返回與正則表達式查找內(nèi)容匹配的第一個子字符串的位置(偏移位)。
stringObj.search(rgExp)
參數(shù)
stringObj
必選項。要在其上進行查找的 String 對象或字符串文字。
rgExp
必選項。包含正則表達式模式和可用標志的正則表達式對象。
說明:如果找到則返回子字符至開始處的偏移位,否則返回-1。
例子6:
復制代碼 代碼如下:

function SearchDemo(){
var r, re; // 聲明變量。
var s = "The rain in Spain falls mainly in the plain.";
re = /falls/i; // 創(chuàng)建正則表達式模式。
re2 = /tom/i;
r = s.search(re); // 查找字符串。
r2 = s.search(re2);
return("r:" + r + ";r2:" + r2); // 返回 Boolean 結(jié)果。
}
document.write(SearchDemo());

輸出:r:18;r2:-1
replace 方法
返回根據(jù)正則表達式進行文字替換后的字符串的復制。
stringObj.replace(rgExp, replaceText)
參數(shù)
stringObj
必選項。要執(zhí)行該替換的 String 對象或字符串文字。該字符串不會被 replace 方法修改。
rgExp
必選項。為包含正則表達式模式或可用標志的正則表達式對象。也可以是 String 對象或文字。如果 rgExp 不是正則表達式對象,它將被轉(zhuǎn)換為字符串,并進行精確的查找;不要嘗試將字符串轉(zhuǎn)化為正則表達式。
replaceText
必選項。是一個String 對象或字符串文字,對于stringObj 中每個匹配 rgExp 中的位置都用該對象所包含的文字加以替換。在 Jscript 5.5 或更新版本中,replaceText 參數(shù)也可以是返回替換文本的函數(shù)。
說明
replace 方法的結(jié)果是一個完成了指定替換的 stringObj 對象的復制。意思為匹配的項進行指定替換,其它不變作為StringObj的原樣返回。
ECMAScript v3 規(guī)定,replace() 方法的參數(shù) replacement 可以是函數(shù)而不是字符串。在這種情況下,每個匹配都調(diào)用該函數(shù),它返回的字符串將作為替換文本使用。該函數(shù)的第一個參數(shù)是匹配模式的字符串。接下來的參數(shù)是與模式中的子表達式匹配的字符串,可以有 0 個或多個這樣的參數(shù)。接下來的參數(shù)是一個整數(shù),聲明了匹配在 stringObject 中出現(xiàn)的位置。最后一個參數(shù)是 stringObject 本身。結(jié)果為將每一匹配的子字符串替換為函數(shù)調(diào)用的相應返回值的字符串值。函數(shù)作參可以進行更為復雜的操作。
例子7:
復制代碼 代碼如下:

function f2c(s) {
var test = /(\d+(\.\d*)?)F\b/g; // 說明華氏溫度可能模式有:123F或123.4F。注意,這里用了g模式
return(s.replace
(test,
function(Regstr,$1,$2,$3,newstrObj) {
return(("br/>" + Regstr +"br/>" + ($1-32) * 1/2) + "C" +"br/>" + //以下兩行進行替換
$2 +"br/>" + $3 +"br/>" + newstrObj +"br/>" );
}
)
);
}
document.write(f2c("Water: 32.2F and Oil: 20.30F."));

輸出結(jié)果:
Water: //不與正則匹配的字符,按原字符輸出
32.2F //與正則相匹配的第一個字符串的原字符串 Regstr
0.10000000000000142C //與正則相匹配的第一個字符串的第一個子模式匹配的替換結(jié)果 $1
.2 //與正則相匹配的第一個字符串的第二個子模式匹配項的替換結(jié)果,這里我們沒有將它替換 $2
7 //與正則相匹配的第一個字符串的第一個子匹配出現(xiàn)的偏移量 $3
Water: 32.2F and Oil: 20.30F. //原字符串 newstrObj
and Oil: //不與正則匹配的字符
20.30F //與正則相匹配的第二個字符串的原字符串
-5.85C //與正則相匹配的第二個字符串的第一個子模式與匹配的替換結(jié)果
.30 //與正則相匹配的第二個字符串的第二個子模式匹配項的替換結(jié)果,這里我們沒有將它替換
22 //與正則相匹配的第二個字符串的第一個子匹配出現(xiàn)的偏移量
Water: 32.2F and Oil: 20.30F. //原字符串
. //不與正則匹配的字符
上面的函數(shù)參數(shù)我們?nèi)坑玫搅恕T趯嶋H中,我們只須用將xxF替換為xxC,根據(jù)要求,我們無須寫這么多參數(shù)。
例子8:
復制代碼 代碼如下:

function f2c(s) {
var test = /(\d+(\.\d*)?)F\b/g; // 說明華氏溫度可能模式有:123F或123.4F
return(s.replace
(test,
function(strObj,$1) {
return((($1-32) * 1/2) + "C");
}
)
);
}
document.write(f2c("Water: 32.2F and Oil: 20.30F."));

輸出:Water: 0.10000000000000142C and Oil: -5.85C.
更多的應用:
例子9:
復制代碼 代碼如下:

function f2c(s) {
var test = /([\d]{4})-([\d]{1,2})-([\d]{1,2})/;
return(s.replace
(test,
function($0,$1,$2,$3) {
return($2 +"/" + $1);
}
)
);
}
document.write(f2c("today: 2011-03-29"));

輸出:today: 03/2011
split 方法
將一個字符串分割為子字符串,然后將結(jié)果作為字符串數(shù)組返回。
stringObj.split([separator[, limit]])
參數(shù)
stringObj
必選項。要被分解的 String 對象或文字。該對象不會被 split 方法修改。
separator
可選項。字符串或 正則表達式 對象,它標識了分隔字符串時使用的是一個還是多個字符。如果忽略該選項,返回包含整個字符串的單一元素數(shù)組。
limit
可選項。該值用來限制返回數(shù)組中的元素個數(shù)。
說明
split 方法的結(jié)果是一個字符串數(shù)組,在 stingObj 中每個出現(xiàn) separator 的位置都要進行分解。separator 不作為任何數(shù)組元素的部分返回。
例子10:
復制代碼 代碼如下:

function SplitDemo(){
var s, ss;
var s = "The rain in Spain falls mainly in the plain.";
// 正則表達式,用不分大不寫的s進行分隔。
ss = s.split(/s/i);
return(ss);
}
document.write(SplitDemo());

輸出:The rain in ,pain fall, mainly in the plain.

js正則表達式之exec()方法、match()方法以及search()方法

先看代碼:

var sToMatch = "test, Tes, tst, tset, Test, Tesyt, sTes";
var reEs = /es/gi;
alert(reEs.exec(sToMatch));
alert(sToMatch.match(reEs));
alert(sToMatch.search(reEs));

三個彈出框內(nèi)容如下:

結(jié)果分析如下:

1、RegExp的exec()方法,有一個字符串參數(shù),返回一個數(shù)組,數(shù)組的第一個條目是第一個匹配;其他的是反向引用。所以第一個返回的結(jié)果是第一個匹配的值es(不區(qū)分大小寫)。

2、String對象有一個match()方法,它返回一個包含在字符串中所有匹配的數(shù)據(jù)。這個方法調(diào)用string對象,同時傳給它一個RegExp對象。所以第二個彈出語句返回的是所有符合正則表達式的數(shù)組。

3、search()的字符串方法與indexOf()有些類似,但是它使用一個RegExp對象而非僅僅一個子字符串。search()方法返回第一個匹配值的位置。所以第三處彈出的是“1”,即第二個字符就匹配了。注意的是search()方法不支持全局匹配正規(guī)表達式(帶參數(shù)g)。

您可能感興趣的文章:
  • JavaScript String.replace函數(shù)參數(shù)實例說明
  • 關于JS字符串函數(shù)String.replace()
  • js正則表達式之replace函數(shù)用法
  • js中字符替換函數(shù)String.replace()使用技巧
  • javascript中使用replaceAll()函數(shù)實現(xiàn)字符替換的方法
  • javascript中字符串替換函數(shù)replace()方法與c# 、vb 替換有一點不同
  • JSP中的字符替換函數(shù) str_replace() 實現(xiàn)!
  • javascript中的replace函數(shù)(帶注釋demo)

標簽:銅川 宣城 西安 泰州 重慶 長沙 無錫 綿陽

巨人網(wǎng)絡通訊聲明:本文標題《js正則函數(shù)match、exec、test、search、replace、split使用介紹集合》,本文關鍵詞  正則,函數(shù),match,exec,test,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《js正則函數(shù)match、exec、test、search、replace、split使用介紹集合》相關的同類信息!
  • 本頁收集關于js正則函數(shù)match、exec、test、search、replace、split使用介紹集合的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产精品成人观看视频国产| 韩国三级做爰高潮HD电影| 丰满大乳女啪啪中文字幕| 交换妻子| 一边亲一边摸一边脱一边?| 999zyz玖玖资源站永久无码| 两女互摸喷水小说| 国产精品日韩| bl攻和受拍床戏真做了| 长泽雅美2007| 666永久视频在线| 97国产精品欧美一区二区三区| 又粗又硬进去好爽A片欧美| 4P一女三男前后夹激视频| 国产成人在线视频播放| 羞羞漫画阅读| 亲嘴扒胸摸屁股视频免费软件| 好吊妞在线新免费观看 | 农村妇女三级在野外| 国精产品一区二区三区公司| 公妇乱婬在线中文字幕HD| 韩国理论片手机在线观看视频| 性生交大片免费观看| 久久久久精品一区二区三区 | 宝贝腿腿抬高一点| 国产成人无精品久久久| 女人脱了内衣让男生摸吻| 三浦理惠子暴雨夜独处之夜| chinesefreexxxxhd老少| 二次元黄毛系统| 国产女性无套?免费网站| ?交重口猎奇你懂的网站 | 狠狠综合久久久久尤物丿| 动漫美女被艹| 亚洲大肥女ass| 狠狠色噜噜狠狠色综合久| 性欧美VideOfree极品| 国产免费一区二区三区四区视频| 当着朋友面在厨房玩弄娇妻 | 午夜小视频网站| 91麻豆精品国产91久久久熟女|