⑴ javaScript中常用符號集合
如下:
==,===相等運算符
!=,!==不等式運算符
= 賦值運算符
&&,||,!邏輯運算符
() 分組運算符
, 逗號運算符
?…: 條件(三元)運算符
|,&,^,~按位OR,AND,XOR和NOT運算符
<<,>>,>>> 位移位運算符
+,-運算符
++,--前/後增/減運算符
void operator
var x = function() vs function x()函數聲明語法
=> 箭頭函數表達式語法
(function(){...})()IIFE (立即調用函數表達式)
someFunction()() 返回其他功能的功能
[],Array()數組符號
/.../ -正則表達式文字
$在正則表達式替換模式:$$,$&,$,$』,$n`
{key: value} 對象文字語法:
可選的鏈接運算符(foo?.bar?.baz):
空位合並運算符(??)
function*,yield,yield* Declaring variables:
var,let,const變數聲明:
this 關鍵詞:
:: 綁定運算符:
new operator
delete operator
label: 標簽
+=Operator
...iter 傳播語法/ Rest參數
|> Operator
** Power Operator
⑵ js的正則表達式的正則前瞻(=)和非捕獲性分組(:)有什麼區別
(?=)會作為匹配校驗,但不會出現在匹配結果字元串裡面
(?:)會作為匹配校驗,並出現在匹配結果字元裡面,它跟(...)不同的地方在於,不作為子匹配返回。
例如:
vardata='windows98isok';
data.match(/windows(?=d+)/);//["windows"]
data.match(/windows(?:d+)/);//["windows98"]
data.match(/windows(d+)/);//["windows98","98"]
⑶ 請教一個關於javascript中match匹配分組的問題
g代表將要匹配的字元串的全部 var reg = /\d/; var str = "1 plus 2 equal 3"; str.match(reg) // ["1"局昌念迅拿] var reg = /\d/g; var str = "桐困1 plus 2 equal 3"; str.match(reg) // ["1","2","3"]
⑷ JS正則表達式基礎認知
正則表達式,又叫規則表達式,英文名Regular Expression,本質是操作字元串
1、模式匹配 表單驗證
2、文本檢索 搜索
3、替換 過濾
簡單,方便,性能高
var reg=new RegExp('規則','模式') 通過構造函數創造
var reg=/規則/模式 通過字面量創建
i 忽略大小寫
g 全局
m 多行
註:不分前後順序
str.match(正則) 返回數組 沒有返回 null
str.search(正則) 返回下標 沒有返回-1
str.replace(正則,替換成誰) 返回替換後的字元串
str.replace(正則,function(s){
s 符合正則條件的字元串
})
\d 數字 /[0-9]/
\s 空格
\w /[0-9a-zA-Z_]/ 單詞
\D 非數字 /[^0-9]/
\S 非空白
\W 非單詞 /[^0-9a-zA-Z_]/
.(點) 代表任意
\. 代表.
\\ 代表\
\\\\ 代表\\
\/ 代表/
只要有特殊意義的都要轉譯
+ {1,m} 若干個 最少1個最多不限
? {0,1} 可有可無
* {0,m} 可以沒有,多了不限
{n} 正好n個
{n,m} 最少n個 最多m個
{n,} 最少n個,最多不限
{,m} × 沒有這種寫法
^ 行首
註:如果^單獨使用,代表字元串列首,配合m使用會識別段落
$ 行尾
[] 中括弧
1、[]裡面的東西都是或的形式
2、[]裡面和放范圍
3、[^] 不代錶行首,代表除去裡面的范圍
4、其他特殊符號代表本身
1、test() 一般配合^ &
功能:用於檢測是否於正則匹配。
返回:布爾值,true匹配,false不匹配
語法:reg.test(檢測的內容)
2 exec()
功能:用於檢測是否於正則匹配。
返回:數組, 不匹配返回null
語法:reg.test(檢測的內容)
再做驗證之前:驗證分兩種,一種強校驗,一種弱校驗
(1)驗證手機號 /1[23457]\d{9}/
(2)驗證座機號 區號-座機號 /(0[1-9]\d-)?[1-9]\d{7}/
(3)驗證qq /[1-9]\d{4,11}/
(4)實現一個trim函數 去掉收尾空格 /^\s+|\s+$/g
(5)中文 /[\u4e00-\u9fa5]/
(6)驗證年齡 18-100 /^1[89]|[2-9]\d|100$/
(7)郵箱: [email protected] /^\w{5,12}@[a-z0-9]{2,8}\.com$/
(8) 過濾html /<[^>]+>/g;
1、分組 ab+ abbbb (ab)+
2、匹配子級
配合replace使用 str.replace(reg,function(s,a,b){
s是 整體
a是第一個括弧的項
b是第二個括弧的項
})
3、優選級 ^(1[89]|[2-9]\d|100)$
4、重復的子項
abbb /(a)(b)\2+/
今天先給大家總結到這兒,後續還會有補充
⑸ JS正則表達式詳解
RegExp是JS的正則表達式對象,實例化一個RegExp對象有 字面量 和 構造函數 2種方式。
字面量實例化RegExp對象
var reg=/js/gi;
開始和結束的斜線/是正則表達式的邊界,//中間的文本是正則表達式文本,後面的gi是正則表達式的修飾符。
構造函數實例化RegExp對象
var reg=new Regex(『js』,』gi』);
第一個參數是正則表達式文本,第二個參數是正則表達式修飾符。
global:RegExp 對象是否具有標志 g。
ignoreCase:RegExp 對象是否具有標志 i。
lastIndex:一個整數,標示開始下一次匹配的字元位置。
multiline:RegExp 對象是否具有標志 m。
source:正則表達式的源文本。
RegExp 對象有 3 個方法:test()、exec() 以及 compile()。
test()
test() 方法檢索字元串中的指定值。返回值是 true 或 false。
示例:
var reg=/js/gi;
var result=reg.test(『I like js』);
結果:true
exec()
exec() 方法檢索字元串中的指定值。返回值是被找到的值。如果沒有發現匹配,則返回 null。
示例:
var reg=/js/gi;
var result=reg.exec(『I like JS』);
結果:JS
compile()
compile() 方法用於改變 RegExp。
compile() 既可以改變檢索模式,也可以添加或刪除第二個參數。
g:global全文搜索,如果不添加此參數,搜索到第一個匹配就會停止
i:ignore case 不區分大小寫,默認是區分大小寫的
m:multiple lines 多行搜索,默認只搜索第一行
正則表達式文本部分包含 原義文本字元 和 元字元, 其中的原義文本字元代表字元本身意義的字元,如abc123之類的字元。
元字元代表有特殊含義非字母字元,如、w、d、+、*、? 等。
常用的元字元
更多的JS正則元字元請參考: http://www.runoob.com/regexp/regexp-metachar.html
一般情況下正則表達式中的一個字元對應字元串中的一個字元,如表達式ab的含義是ab。
表達式中用 [] 來定義一個字元類,表示可以匹配[]裡面的這類字元,是一個泛指,而不是一一對應的關系。
如表達式[abc123],表示有其中一個字元串都可以匹配。
在字元類裡面使用橫線-連接2個數字或者字母就可以構建一個范圍類,如[a-zA-z0-9-]表示可以匹配26個大小寫字母和0-9的全部數字以及橫線-。
注意,要匹配橫線」-「,必須把橫線放在最後面。
預定義類可以理解為JS默認給我們寫好的范圍類,讓我們可以使用一個簡單的元字元來使用它。如」w」就是一個預定義類,它等價於范圍類[A-Za-z0-9_];「.」可以匹配除 「 」 之外的任何單個字元。
邊界包含2種,一種是以字元串開始或結尾的邊界,另一種是單詞邊界
量詞表示可以匹配連續多次的元字元
JS正則表達式默認是貪婪模式匹配,它會以最多匹配原則進行查找,非貪婪模式可以讓表達式以最少匹配原則進行查找。
非貪婪模式只需要在量詞後面加上」?」即可,如」123456789″字元串想以3個數字為一組進行匹配表達式寫法/d{3,5}?/g。
表達式中用 () 來定義一個分組,使元字元可以作用於一個表達式字元串組合,如/(js|php){3}/gi。
表達式中的每一個分組匹配的內容都是一個可以捕獲的變數,可以使用$1、$2、$3… 來取值,如表達式/(d{4})-(d{2})-(d{2})/中包含$1、$2、$3。如果想忽略分組匹配的內容,需要在分組前面增加「?:」,就可以得到分組匹配之外的內容。
前瞻就是正則表達式後面加上斷言部分,它不但要匹配表達式部分,還需要滿足斷言部分,匹配的結果不會包含斷言部分。
正向前瞻 exp(?=assert) 如 「w(?=d)」
負向前瞻 exp(?!assert) 如 「w(?!d)」
match()
stringObject.match(regexp)
match() 方法可在字元串內檢索指定的值,或找到一個或多個正則表達式的匹配。
如果 regexp 沒有標志 g,那麼 match() 方法就只能在 stringObject 中執行一次匹配。
如果沒有找到任何匹配的文本, match() 將返回 null。
否則,它將返回一個數組,其中存放了與它找到的匹配文本有關的信息。該數組的第 0 個元素存放的是匹配文本,而其餘的元素存放的是與正則表達式的子表達式匹配的文本。
search()
stringObject.search(regexp)
search() 方法不執行全局匹配,它將忽略標志 g。它同時忽略 regexp 的 lastIndex 屬性,並且總是從字元串的開始進行檢索,這意味著它總是返回 stringObject 的第一個匹配的位置。
replace()
stringObject.replace(regexp/substr,replacement)
字元串 stringObject 的 replace() 方法執行的是查找並替換的操作。它將在 stringObject 中查找與 regexp 相匹配的子字元串,然後用 replacement 來替換這些子串。如果 regexp 具有全局標志 g,那麼 replace() 方法將替換所有匹配的子串。否則,它只替換第一個匹配子串。
replacement 可以是字元串,也可以是函數。如果它是字元串,那麼每個匹配都將由字元串替換。但是 replacement 中的 $ 字元具有特定的含義。如下表所示,它說明從模式匹配得到的字元串將用於替換。
split()
stringObject.split(separator,howmany)
如果 separator 是包含子表達式的正則表達式,那麼返回的數組中包括與這些子表達式匹配的字串(但不包括與整個正則表達式匹配的文本)
正則表達式語法語意測試工具: https://regexper.com/
⑹ 在JavaScript中,如何定義一維數組Array
javascript 定義一維數組有兩種方式。
實例後版賦值權。
vararr=newArray();
arr[0]='one';
arr[1]='two';
2.實例時賦值。
vararr=newArray('one','two');