欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS的replace方法與正則表達(dá)式結(jié)合應(yīng)用講解

 更新時(shí)間:2007年12月29日 20:06:58   作者:  
replace方法的語(yǔ)法是:stringObj.replace(rgExp, replaceText) 其中stringObj是字符串(string),reExp可以是正則表達(dá)式對(duì)象(RegExp)也可以是字符串(string),replaceText是替代查找到的字符串。。為了幫助大家更好的理解,下面舉個(gè)簡(jiǎn)單例子說(shuō)明一下
復(fù)制代碼 代碼如下:

<script language="javascript"> 
var stringObj="終古人民共和國(guó),終古人民"; 

//替換錯(cuò)別字“終古”為“中國(guó)” 
//并返回替換后的新字符 
//原字符串stringObj的值沒(méi)有改變 
var newstr=stringObj.replace("終古","中國(guó)");  
alert(newstr); 
</script> 



   比我聰明的你,看完上面的例子之后,會(huì)發(fā)現(xiàn)第二個(gè)錯(cuò)別字“終古”并沒(méi)有被替換成“中國(guó)”,我們可以執(zhí)行二次replace方法把第二個(gè)錯(cuò)別字“終古”也替換掉,程序經(jīng)過(guò)改進(jìn)之后如下: 


   我們可以仔細(xì)的想一下,如果有N的N次方個(gè)錯(cuò)別字,是不是也要執(zhí)行N的N次方replace方法來(lái)替換掉錯(cuò)別字呢??呵,不用怕,有了正則表達(dá)式之后不用一個(gè)錯(cuò)別字要執(zhí)行一次replace方法。。程序經(jīng)過(guò)改進(jìn)之后的代碼如下



上面講的是replace方法最簡(jiǎn)單的應(yīng)用,不知道大家有沒(méi)有看懂??下面開(kāi)始講稍微復(fù)雜一點(diǎn)的應(yīng)用。。


   大家在一些網(wǎng)站上搜索文章的時(shí)候,會(huì)發(fā)現(xiàn)這么一個(gè)現(xiàn)象,就是搜索的關(guān)鍵字會(huì)高亮改變顏色顯示出來(lái)??這是怎么實(shí)現(xiàn)的呢??其實(shí)我們可以用正則表達(dá)式來(lái)實(shí)現(xiàn),具體怎么樣實(shí)現(xiàn)呢?簡(jiǎn)單的原理請(qǐng)看下面的代碼





上面的程序缺少互動(dòng)性,我們?cè)俑倪M(jìn)一下程序,實(shí)現(xiàn)可以自主輸入要查找的字符



  可能大家都會(huì)對(duì)$1這個(gè)特殊字符表示什么意思不是很理解,其實(shí)$1表示的就是左邊表達(dá)式中括號(hào)內(nèi)的字符,即第一個(gè)子匹配,同理可得$2表示第二個(gè)子匹配。。什么是子匹配呢??通俗點(diǎn)講,就是左邊每一個(gè)括號(hào)是第一個(gè)字匹配,第二個(gè)括號(hào)是第二個(gè)子匹配。。


   當(dāng)我們要把查找到的字符進(jìn)行運(yùn)算的時(shí)候,怎么樣實(shí)現(xiàn)呢??在實(shí)現(xiàn)之前,我們先講一下怎么樣獲取某一個(gè)函數(shù)的參數(shù)。。在函數(shù)Function的內(nèi)部,有一個(gè)arguments集合,這個(gè)集合存儲(chǔ)了當(dāng)前函數(shù)的所有參數(shù),通過(guò)arguments可以獲取到函數(shù)的所有參數(shù),為了大家理解,請(qǐng)看下面的代碼





看懂上面的程序之后,我們?cè)賮?lái)看下面一個(gè)有趣的程序 



    我們驚奇的發(fā)現(xiàn),匿名函數(shù)竟然被執(zhí)行了二次,并且在函數(shù)里還帶有三個(gè)參數(shù),為什么會(huì)執(zhí)行二次呢??這個(gè)很容易想到,因?yàn)槲覀儗懙恼齽t表達(dá)式是匹配單個(gè)數(shù)字的,而被檢測(cè)的字符串剛好也有二個(gè)數(shù)字,故匿名函數(shù)被執(zhí)行了二次。。在匿名函數(shù)內(nèi)部的那三個(gè)參數(shù)到底是什么內(nèi)容呢??為了弄清這個(gè)問(wèn)題,我們看下面的代碼。 

    經(jīng)過(guò)觀察我們發(fā)現(xiàn),第一個(gè)參數(shù)表示匹配到的字符,第二個(gè)參數(shù)表示匹配時(shí)的字符最小索引位置(RegExp.index),第三個(gè)參數(shù)表示被匹配的字符串(RegExp.input)。其實(shí)這些參數(shù)的個(gè)數(shù),還會(huì)隨著子匹配的變多而變多的。弄清這些問(wèn)題之后,我們可以用另外的一種寫法



看了上面的程序,原來(lái)可以對(duì)匹配到的字符為所欲為。下面簡(jiǎn)單舉一個(gè)應(yīng)用的例子

相關(guān)文章

  • toString.call()通用的判斷數(shù)據(jù)類型方法示例

    toString.call()通用的判斷數(shù)據(jù)類型方法示例

    這篇文章主要給大家介紹了關(guān)于toString.call()通用的判斷數(shù)據(jù)類型方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • javascript基礎(chǔ)進(jìn)階_深入剖析執(zhí)行環(huán)境及作用域鏈

    javascript基礎(chǔ)進(jìn)階_深入剖析執(zhí)行環(huán)境及作用域鏈

    下面小編就為大家?guī)?lái)一篇javascript基礎(chǔ)進(jìn)階_深入剖析執(zhí)行環(huán)境及作用域鏈。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • bootstrap網(wǎng)格系統(tǒng)使用方法解析

    bootstrap網(wǎng)格系統(tǒng)使用方法解析

    這篇文章主要為大家詳細(xì)解析了bootstrap網(wǎng)絡(luò)系統(tǒng)使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 淺談js中StringBuffer類的實(shí)現(xiàn)方法及使用

    淺談js中StringBuffer類的實(shí)現(xiàn)方法及使用

    下面小編就為大家?guī)?lái)一篇淺談js中StringBuffer類的實(shí)現(xiàn)方法及使用。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • 微信小程序動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題的實(shí)現(xiàn)步驟

    微信小程序動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題的實(shí)現(xiàn)步驟

    實(shí)際開(kāi)發(fā)中很多時(shí)候我們需要通過(guò)上個(gè)頁(yè)面?zhèn)鬟^(guò)來(lái)的值動(dòng)態(tài)的更改標(biāo)題欄文字,下面這篇文章主要給大家介紹了關(guān)于微信小程序動(dòng)態(tài)設(shè)置導(dǎo)航欄標(biāo)題的實(shí)現(xiàn)步驟,需要的朋友可以參考下
    2023-02-02
  • ASP中Sub和Function的區(qū)別說(shuō)明

    ASP中Sub和Function的區(qū)別說(shuō)明

    主要的區(qū)別是有返回值,一般sub是用來(lái)調(diào)用大量的內(nèi)容的時(shí)候用sub,對(duì)于需要計(jì)算并需要返回值的時(shí)候用function,多用function定義函數(shù)。
    2011-01-01
  • 原生javascript AJAX 三級(jí)聯(lián)動(dòng)的實(shí)現(xiàn)代碼

    原生javascript AJAX 三級(jí)聯(lián)動(dòng)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了原生javascript AJAX 三級(jí)聯(lián)動(dòng)的實(shí)現(xiàn)代碼,非常不錯(cuò)代碼簡(jiǎn)單易懂,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • 了解在JavaScript中將值轉(zhuǎn)換為字符串的5種方法

    了解在JavaScript中將值轉(zhuǎn)換為字符串的5種方法

    這篇文章主要介紹了在JavaScript中將值轉(zhuǎn)換為字符串的5種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,下面小編就和大家一起來(lái)學(xué)習(xí)下吧
    2019-06-06
  • Three.js實(shí)現(xiàn)臉書元宇宙3D動(dòng)態(tài)Logo效果

    Three.js實(shí)現(xiàn)臉書元宇宙3D動(dòng)態(tài)Logo效果

    本文主要講述通過(guò) Three.js + Blender 技術(shù)棧,實(shí)現(xiàn) Meta 公司炫酷的 3D 動(dòng)態(tài) Logo,內(nèi)容包括基礎(chǔ)模型圓環(huán)、環(huán)面扭結(jié)、管道及模型生成、模型加載、添加動(dòng)畫、添加點(diǎn)擊事件、更換材質(zhì)等
    2021-11-11
  • JScript面向事件驅(qū)動(dòng)的編程

    JScript面向事件驅(qū)動(dòng)的編程

    JScript面向事件驅(qū)動(dòng)的編程...
    2007-01-01

最新評(píng)論