JS正則表達式常見使用方法


定義和使用

var patt1 = new RegExp( "hello");
var patt2 = /world/ ;

test方法
test() 方法檢索字符串中的指定值。返回值是 true 或 false。

var pat = /my/ ;
var str = "this is my code..." ;
console.log(pat.test(str)); // true

exec方法
exec() 方法檢索字符串中的指定值。返回值是被找到的值。如果沒有發現匹配,則返回 null。

var pat = /hello/ ;
console.log(pat.exec("oh hello world" )); //返還 hello

正則表達式類型
/pattern/attributes
參數 attributes 是一個可選的字符串,常用屬性 “g”、 “i” ,分別用於指定全局匹配、區分大小寫的匹配。

//不區分大小寫
var str = "Visit Hunger" ;
var patt1 = /hunger/i ;
console.log(str.match(patt1));  // 全局匹配
var str="hello hunger valley! I am hunger" ;
var patt1= /hunger/g; console.log(str.match(patt1));  // 不區分大小寫,全局匹配 var str= "hello Hunger valley! I am hunger"; var patt1=/hunger/gi ; console.log(str.match(patt1));

字符串正則

  1. search
    字符串查找
var str="Visit W3School!" ;
console.log(str.search(/w3school/ )); //-1 console.log(str.serach(/w3school/i )); // 6
  1. match
    字符串匹配
var str="1 plus 2 equal 33" ;
console.log(str.match(/\d+/ ));   //[1]
console.log(str.match(/\d+/g ));  //[1,2,33]
  1. replace
    字符串替換
var str="Hello JI! oh I am hunger"
console.log(str.replace(/Hunger/ , "valley")); console.log(str.replace(/hunger/ig , "hunger"));
  1. split
    字符串分割
var str = "Hello Hunger , oh I am Hunger" ;
str.split("");
str.split(/\s+/);

正則寫法
*
[abc] 查找方括號之間的任何字符。

var str="Is this all there is?" ;
var patt1=/[a-h]/g ;
 console.log(str.match(patt1));
* 

[^abc] 查找任何不在方括號之間的字符。

var str="hello jikexueyuan!" ;
var patt1=/[^jike]/g ;
console.log(str.match(patt1));
* 

[0-9] 查找任何從 0 至 9 的數字。
*
[a-z] 查找任何從小寫 a 到小寫 z 的字符。
*
[A-Z] 查找任何從大寫 A 到大寫 Z 的字符。
*
[A-z] 查找任何從大寫 A 到小寫 z 的字符。
*
[adgk] 查找給定集合內的任何字符。
*
[^adgk] 查找給定集合外的任何字符。
*
red|blue|green 查找任何指定的選項。

var str="hello hunger! How are you?" ;
var patt1=/hello|you/g ; c
onsole.log(str.match(patt1));
* 

. 查找單個字符,除了換行和行結束符。

var str="That's hot!" ;
var patt1=/h.t/g ;
document.write(str.match(patt1));
* 

\w 查找單詞字符(字母、數字、下划線 )。

var str="Give 100%!" ;
 var patt1= /\w/g;
document.write(str.match(patt1));
* 

\W 查找非單詞字符。

var str="Give 100%!" ;  var patt1= /\W/g; document.write(str.match(patt1));
* 

\d 查找數字。

var str="Give 100%!" ; 
var patt1=/\d/g ;
document.write(str.match(patt1));
* 

\D 查找非數字字符。

var str="Give 100%!" ;  var patt1= /\D/g; document.write(str.match(patt1));
	* 
\s 查找空白字符(空格、 tab、換行、回車 )var str="Is this all there is?" ;
  var patt1= /\s/g; document .write(str.match(patt1));
	* 

\S 查找非空白字符。

var str="Is this all there is?" ;  var patt1= /\S/g; document.write(str.match(patt1));
* 

\b 匹配單詞邊界。

/\bm/ 匹配 “moon” 中的 ‘m’;
/oo\b/ 不匹配 “moon” 中的 ‘oo’,因為 ‘oo’ 后面的 ‘n’ 是一個單詞字符;
/oon\b/ 匹配 “moon” 中的 ‘oon’,因為 ‘oon’ 位於字符串的末端,后面沒有單詞字符;

var str= "Hello jikexueyuan"; 
var patt1=/\bjikexueyuan/g ;
document.write(str.match(patt1));
* 

\B 匹配非單詞邊界。
*
\n 查找換行符。

var str="Hello Hunger.\n be a FE." ; 
var patt1=/\n/g ; document.write(str.search(patt1));
	* 

n+ 匹配任何包含至少一個 n 的字符串。

var str="Hello HHunger! Hello World!" ; 
var patt1=/H+/g ;
document.write(str.match(patt1)); 
var str="Hello Hunger! Hello World!" ;
 var patt1= /\w+/g; document .write(str.match(patt1));
	* 

n* 匹配任何包含零個或多個 n 的字符串。

var str="Hellooo Hunger! Hello World!" ;  var patt1= /lo*/g; document.write(str.match(patt1))
* 

n? 匹配任何包含零個或一個 n 的字符串。

var str="1, 100 or 1000?" ;  var patt1= /10?/g; document.write(str.match(patt1));
* 

n{X} 匹配包含 X 個 n 的序列的字符串。

var str="100, 1000 or 10000?" ; var patt1= /\d{4}/g;  document.write(str.match(patt1));
* 

n{X,Y} 匹配包含 X 或 Y 個 n 的序列的字符串。

var str="100, 1000 or 10000?" ; var patt1= /\d{3,4}/g;  document.write(str.match(patt1));
* 

n{X,} 匹配包含至少 X 個 n 的序列的字符串。

var str="100, 1000 or 10000?" ; var patt1= /\d{3,}/g;  document.write(str.match(patt1));
* 

n$ 匹配任何結尾為 n 的字符串。

var str="Is this his" ; var patt1= /is$/g; document.write(str.match(patt1));
* 

^n 匹配任何開頭為 n 的字符串。

var str="Is this his" ; var patt1= /^Is/g; document.write(str.match(patt1));

常見正則
*
漢字: [\u4e00-\u9fa5]
*
手機號: 1[0-9]{10}
*
郵箱: (\S)+[@]{1}(\S)+[.]{1}(\w)+

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM