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

主頁 > 知識庫 > RegExp 隨筆 JavaScript RegExp 對象

RegExp 隨筆 JavaScript RegExp 對象

熱門標簽:實用地圖標注app 地圖標注字母的軟件 宿遷智能外呼系統供應商 地圖標注商戶中心要收錢多少 線上教育ai外呼系統 菏澤智能ai電銷機器人銷售公司 css百度地圖標注位置顯示 鄂州人工智能電銷機器人軟件 400免費電話去哪申請

概述

RegExp 的構造函數創建了一個正則表達式對象,用模式來匹配文本。

有關正則表達式介紹,請閱讀JavaScript指南中的正則表達式章節。

語法

文字和構造符號是可能的:
/pattern/flags new RegExp(pattern [, flags])

參數

pattern
正則表達式的文本
flags
如果指定,標志可以具有以下值的任意組合:

g
全局匹配
i
忽略大小寫
m
多行;讓開始和結束字符(^ 和 $)工作在多行模式工作(例如,^ 和 $ 可以匹配字符串中每一行的開始和結束(行是由 \n 或 \r 分割的),而不只是整個輸入字符串的最開始和最末尾處。
u
Unicode。把模式當作Unicode代碼點(code points)的序列。
y
黏度; 在目標字符串中,只從正則表達式的lastIndex屬性指定的顯示位置開始匹配(并且不試圖從任何之后的索引匹配)。
描述
有兩種方法可以創建一個正則對象:字面量和構造函數。要表示字符串,字面量形式不使用引號,而傳遞給構造函數的參數使用引號。下面表達式創建相同的正則表達式:

/ab+c/i;
new RegExp('ab+c', 'i');
new RegExp(/ab+c/, 'i');

當表達式被賦值時,字面量形式提供正則表達式的編譯(compilation)狀態,當正則表達式保持為常量時使用字面量。例如當你在循環中使用字面量構造一個正則表達式時,正則表達式不會在每一次迭代中都被重新編譯(recompiled)。
而正則表達式對象的構造函數,如 new RegExp('ab+c') 提供了正則表達式運行時編譯(runtime compilation)。如果你知道正則表達式模式將會改變,或者你事先不知道什么模式,而是從另一個來源獲取,如用戶輸入,這些情況都可以使用構造函數。
從ECMAScript 6開始,當第一個參數為正則表達式而第二個標志參數存在時,new RegExp(/ab+c/, 'i')不再拋出TypeError (“當從其他正則表達式進行構造時不支持標志”)的異常,取而代之,將使用這些參數創建一個新的正則表達式。

當使用構造函數創造正則對象時,需要常規的字符轉義規則(在前面加反斜杠 \)。比如,以下是等價的:

var re = new RegExp("\\w+");
var re = /\w+/;

以字面量定義正則表達式
var expression = /pattern/ flags;
pattern 部分可以是任何簡單或復雜的正則表達示
flage 標明正則表達式的行為 1.g:全局模式,不會在發現第一個匹配項后停止 2.i:不區分大小寫模式 3.m:多行模式
例:

var pattern1 = /at/g; //匹配字符串中所有at
var pattern2 = /[bc]at/i; //匹配第一個“bat”或“cat”,不區分大小寫
var pattern3 = /.at/gi; //全局匹配以.at“結尾”的三個字符。不區分小寫

模式中使用的所有元字符都必須轉義。正則表達式中的元字符包括:([{\^$|?*+.}])
例:

var pattern4 = /\[bc\]at/i; //匹配第一個“[bc]at”,不區分大小寫

使用RegExp構造函數,接受2個參數,參數1:要匹配的字符串模式,參數2:可選的標志行為
例:

var pattern5 = new RegExp("[bc]at", "i");

注:因為RegExp構造函數的模式參數都是字符串,所以在某些情況下要對字符串進行雙重轉義。所有元字符必須雙重轉義

例:
字面量        等價字符串
/\[bc\]at/      "\\[bc\\]at"
/\.at/        "\\.at"
/name/\age/    "name\\/age"
/\d.\d{1,2}/    "\\d.\\d{1,2}"
/\w\\hello\\123/ "\\w\\\\hello\\\\123"

注:使用字面量和實例化創建正則表達式不一樣,字面量始終會共享同一個RegExp實例(ECMAScript3)。使用構造函數創建的每一個新的RegExp實例都是一個新實例。

RegExp實例屬性

console.log(pattern5.global); //false 是否設置了g標志
console.log(pattern5.ignoreCase); //true 是否設置了i標志
console.log(pattern5.multiline); //false 是否設置了m標志
console.log(pattern5.lastIndex); //0 開始搜索下一個匹配項的起始位置
console.log(pattern5.source); //[bc]at 正則表達式的字符串表示

繼承屬性

console.log(pattern5.toString()); // /[bc]at/i 正則表達式的字面量表示
console.log(pattern5.toLocaleString()); // /[bc]at/i 正則表達式的字面量表示
console.log(pattern5.valueOf()); // /[bc]at/i 正則表達式的字面量表示

RegExp實例方法
方法一:exec(),接受一個參數,既應用模式字符串。返回返回包含第一個匹配項信息的數組,在沒有的情況下返回null,返回的數組實例包含兩個屬性index(匹配項在字符中的位置)和input(應用正則的字符串)。

var text = "huang jin liang shi ge hao ren";
var pattern6 = new RegExp("huang( jin liAng( shi ge hao ren)?)?", "i");
var matches = pattern6.exec(text);
console.log(matches); 
//[ 'huang jin liang shi ge hao ren',
// ' jin liang shi ge hao ren',
// ' shi ge hao ren',
// index: 0,
// input: 'huang jin liang shi ge hao ren' ]

var text1 = "cat, bat, sat";
var pattern7 = new RegExp(".at")
var matches1 = pattern7.exec(text1);
console.log(matches1); //cat

var pattern8 = new RegExp(".at", "gm");
var matches2 = pattern8.exec(text1);
console.log(matches2); //cat
var matches3 = pattern8.exec(text1);
console.log(matches3); //bat
var matches4 = pattern8.exec(text1);
console.log(matches4); //sat
var matches5 = pattern8.exec(text1);
console.log(matches5); //null

方法二:test(),接受一個參數,既應用模式字符串。該模式與該參數匹配的情況下返回true,反之false

var text2 = "000-00-0000";
var pattern9 = new RegExp("\\d{3}-\\d{2}-\\d{4}");
console.log(pattern9.test(text2))
console.log(text2);
if (pattern9.test(text2)) {
console.log("匹配成功");
} else {
console.log("匹配失敗");
}

構造函數屬性(某些瀏覽器不支持)
長屬性名    短屬性名 說明
input      $_    最近一次要匹配的字符串
lastMatch    $    最近一次匹配項
lastParen    $+    最近一次捕獲組
leftContext    $`    input字符串中lastMatch之前的文本
multiline    $*    布爾,是否是多行模式
rightContext $'    input字符串中lastMatch之后的文本
        $1~$9 分別用于存儲第幾個捕獲組

在ECMAScript局限性
1.匹配字符串開始和結束的\A和\Z錨
2.向后查找
3.并集和交集類
4.原子組
5.Unicode支持(單個字符除外)
6.命名捕獲組
7.s和x匹配模式
8.條件匹配
9.正則表達式注釋

剛發現一個js中匹配多行的方法

script>
var s = "Please yes\nmake my day!";
alert(s.match(/yes.*day/));
// Returns null
alert(s.match(/yes[^]*day/));
// Returns 'yes\nmake my day'
/script>

可惜了,editplus不能用,很多時候還是使用dw比較方便。

您可能感興趣的文章:
  • 深入淺析JavaScript中的RegExp對象
  • 詳解JavaScript RegExp對象
  • 淺談JS正則表達式的RegExp對象和括號的使用
  • JS正則中的RegExp對象對象
  • js正則表達式之RegExp對象之compile方法 編譯正則表達式
  • javascript RegExp對象(正則表達式)
  • JavaScript RegExp 對象用法詳解

標簽:三亞 梅州 池州 恩施 咸陽 鞍山 六安 綿陽

巨人網絡通訊聲明:本文標題《RegExp 隨筆 JavaScript RegExp 對象》,本文關鍵詞  RegExp,隨筆,JavaScript,對象,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《RegExp 隨筆 JavaScript RegExp 對象》相關的同類信息!
  • 本頁收集關于RegExp 隨筆 JavaScript RegExp 對象的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国产精品日本欧美一区二区| 日本19禁综艺直接啪啪| でも私はあなたより賢いです意思 | 日本中文一区| 韩世雅全部三级| 成人动漫在线| 草蜢社区在线观看www| 精品欧美一区二区三区久久久| 东北妇女多毛XXXHD| 日本一级婬片A片AAA视频| Japanese少妇高潮潮喷| 欧美娇小性xxxx| 欧美videos13_14| 日本爱的色戒在线观看| 香港黄业之偷食少妇心| 杨门女将肉艳史全文阅| 久久久久综合网久久| 拔出来~啊你tm别?了徐海乔| 清纯白嫩美女正无套播放| 主人调教打屁股| jux900被公每天侵犯的我| 对白刺激国语子与伦| 狠狠的撞击发泄h| 鞭打+跪趴+调教+sm主奴视频| 色婷婷五月亚洲一区二区91| 男生摸女生胸视频| 无码人妻一区二区三区免费京洛会| 小黄文男男| 污在线视频| 久久久久久无码日韩欧美电影| 久久久Av人妻互伦无码菜单 | 黄瓜视频成人A片入口| Free???性HD另类医生| 被多人强伦的小柔小说片段| jiZZJIZZ成熟丰满少妇| 久久爽人人爽久久爽av杏吧| 舔下面的视频| 国产精品久久久久久久久久久久人四虎 | 热99这里只有精品| 最新黄色免费网站| 调教mm被?免费视频|