JavaScript 實現基礎 Regex

來源:互聯網
上載者:User

JavaScript通過RegExp類來支援Regex,舉一個最簡單的例子: 複製代碼 代碼如下:var regApple = new RegExp("apple");

它可以匹配一個字串中出現的第一個"apple"字串,並且對大小寫敏感。在構造方法中加入第二個參數"g"則代表的搜尋出字串中所有的 "apple",這裡"g"代表"global"。如果第二個參數為"i",則代表著case-insensitive,匹配過程中將不考慮字母的大小寫。將上述兩者綜合起來,可以搜尋出所有"apple"字串,並且不考慮大小寫問題。 複製代碼 代碼如下:var regApple = new RegExp("apple", "gi");

Regex有著並不唯一的表示方法,使用Perl語言中的文法,可以將上述運算式表示為: 複製代碼 代碼如下:var regApple = /apple/gi;

建立了一個RegExp對象後,RegExp的方法可以構造出不同的匹配方式,因為Regex是對字串進行的操作,所以String的一些方法在構造Regex的過程中也扮演著重要角色。
RegExp對象的方法 複製代碼 代碼如下:var sampleString = "Greenapple";
var regApple = /apple/;
alert(regApple.test(sampleString));

上面代碼輸出的結果是"true",因為sampleString中包含了需要匹配的字串"apple",這是最簡單的檢測方式。有時,我們需要知道匹配的詳細結果,例如: 複製代碼 代碼如下:var sampleString = "green apples, red apples";
var regApple = /apple/g;
var arr = regApple.exec(sampleString);

通過使用exec()方法,返回的arr是關於匹配結果的一個數組,包括每一個匹配的值及其所在的段,例如上例中是"green apples"還是"red apples"。match()方法有著和exec()相同的功能,只是表達方式不同: 複製代碼 代碼如下:var sampleString = "green apples, red apples";
var regApple = /apple/g;
var arr = sampleString.match(regApple);

search()方法和indexOf()比較類似,返回第一個匹配的字串所在的位置: 複製代碼 代碼如下:var sampleString = "green apples, red apples";
var regApple = /apple/gi;
alert(sampleString.search(regApple)); //輸出"6"

String的方法
String的replace()方法可以將指定的字串替換為另一個字串: 複製代碼 代碼如下:var sampleString = "There is a green apple.";
alert(sampleString.replace("green", "red")); //輸出"There is a red apple."

將replace()的第一個參數替換為一個Regex,可以達到同樣的效果: 複製代碼 代碼如下:var sampleString = "There is a green apple.";
var regApple = /apple/;
alert(sampleString.replace(regApple, "red")); //輸出"There is a red apple."

replace()的第二個參數可以替換為一個function(),該function()接受一個匹配字串作為參數,返回一個替換字串。(存在疑問)
使用Regex可以實現String的split()方法相同的功能。 複製代碼 代碼如下:var fruit = "apple,pear,lemon";
var arr = fruit.split(",");

使用Regex: 複製代碼 代碼如下:var fruit = "apple,pear,lemon";
var reg = /\,/;
var arr = fruit.split(reg);

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.