麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Regex > 正文

關(guān)于瀏覽器中正則表達式陷阱的解析

2024-09-07 17:40:07
字體:
供稿:網(wǎng)友

在js內(nèi)置對象中我們會經(jīng)常使用正則表達式,但是你知道我們在使用正則表達式的時候里面含有嚴重的陷阱嗎?那么我們現(xiàn)在就去看看關(guān)于瀏覽器中正則表達式陷阱的解析。

在本章開始前 我要引入一個例子 來說明這種不徹底的 變態(tài)的優(yōu)化 到底合理還是不合理...

c# 中的 字符串直接量 做的優(yōu)化 就非常徹底...這種優(yōu)化我們應(yīng)該是歡迎的...

?string str="franky";

string str2="franky";

在內(nèi)存中 只有一份 字符串對象 而str和str2 具備相同的一份引用. 很明顯 這非常合理.

string n = "franky",? n2 = "franky";
Response.Write((Object.ReferenceEquals(n,n2)).ToString());//True.

那么 一些特殊情況下? 有些瀏覽器 為正則表達式直接量也做了類似的優(yōu)化.

alert(//d/==//d/);//所有瀏覽器都是false 這很合理 因為正則表達式直接量 同 [] 數(shù)組直接量 {}對象直接量一樣 都是引用類型?

我們再看看哪些情況下哪些瀏覽器做了優(yōu)化

??? function f2() {
??????? return //d/;
??? }

?????? alert(f2() == f2());

//這里的結(jié)果就有不同了

ie6 7 8? opear10 safari4 都返回false? (我虛擬機里safari3壞了沒做測試.如果誰有 幫忙測下告訴我結(jié)果.謝謝 我估計safari3 會返回true.原因是 maxthon3用的引擎貌似就是safari3 的)?

但是

firefox 2.0 3.0+ 3.5 3.6? chrome 4 5 opear9? maxthon3 demo版 ?使用webkit引擎下 都返回true

有趣的地方在于 opera9 做了優(yōu)化 而opera10 取消了這種優(yōu)化. 看來至少opera團隊認為這種優(yōu)化時不恰當?shù)?..(變相支持了我的觀點.)

?

看到這里 你也許會奇怪 是不是 bug而不是所謂優(yōu)化??? 也許是閉包對象 出了什么問題或者 是 函數(shù)對象上的某些bug引起的?

那么我們看看下面的例子:

for (var i = 0; i < 10; i++) document.writeln(//d/g.test('' + i));

不同瀏覽器 輸出結(jié)果的 差異 完全符合上面 是否做優(yōu)化的分類.

即沒有 做優(yōu)化的瀏覽器 一律返回true 而作了優(yōu)化的瀏覽器 則是 true false true false 交替的結(jié)果.

我們這里只是一個 循環(huán) ..js中的循環(huán)沒有獨立的作用域 更不會產(chǎn)生閉包對象 那么可以肯定 引起這個怪異問題的 根本原因就是某些瀏覽器自作聰明的優(yōu)化.

可能大家不太理解 test的結(jié)果 差異來自哪里...? 答案是 test 同 exec 一樣 如果 直接量后面有/g? .設(shè)置了 global全局查找參數(shù) 的話 那么 同一個test對象 會記錄上次 匹配字符的索引位置.下次再 匹配時 會從這個位置開始..如果沒有 則 匹配索引<0 下次在此匹配時 就仍然從0位置字符開始.

所以上面這個測試 使用 exec 也是可以的.

那么 這里 如何避免瀏覽器差異呢? 簡單的辦法 去掉/g即可

這里我們?yōu)榱硕惚芟葳?就要 記得一個約定.? 請盡量不要使用 一個正則直接量 在函數(shù)體內(nèi) 或 循環(huán)內(nèi). 如果一定要如此 請使用new RegExp('/d',g);這種.

對于exec 盡量用 string.match代替. 因為match 強制你依靠是否有 /g 來全局查找..不會產(chǎn)生歧義.

對于test 如果是循環(huán)內(nèi) 也可以考慮? var reg=//d/; //這里要吧/g去掉..請不要忘記哦

for (var i = 0; i < 10; i++) document.writeln(reg.test('' + i));

事實上這樣用是最合理的辦法 .原因是 這里我們只產(chǎn)生一個正則對象 并反復(fù)使用他.. 本質(zhì)上也是為了優(yōu)化。但是我們避開了 瀏覽器自己的優(yōu)化差異 導(dǎo)致的不同結(jié)果.

最后我們發(fā)現(xiàn) 所謂陷阱 發(fā)生主要是 /g使用不當.無論是 exec 還是test都是如此? 如果合理使用/g 無論瀏覽器是否存在變態(tài)的優(yōu)化. 執(zhí)行結(jié)果都將是正確的...唯一的區(qū)別 只在于 做了優(yōu)化的瀏覽器 不需要反復(fù)產(chǎn)生一個 正則對象然后再垃圾回收 再產(chǎn)生一個正則對象....如此反復(fù)而已...

以上就是關(guān)于瀏覽器中正則表達式陷阱的解析,其實我們可以發(fā)現(xiàn)陷阱主要發(fā)生在 /g使用不當?shù)臅r候,只有我們遵守上面幾個原則,就可以避免這種問題的發(fā)生。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 性欧美暴力猛交69hd | 成人在线免费观看视频 | 羞羞答答影院 | 91成人在线网站 | 国产精品成人av片免费看最爱 | 欧美一级黄 | 天堂二区| 色中色在线播放 | 亚洲精品永久视频 | 久久精品日产第一区二区三区 | 国产 日韩 一区 | 亚洲精品一区中文字幕 | 九九视频精品在线 | 国产一级二级在线播放 | 午夜视频在线 | 久久久久久久久久久一区 | 日本看片一区二区三区高清 | 人禽l交免费视频观看 视频 | 激情视频导航 | 欧美极品欧美精品欧美视频 | 99在线精品视频免费观看20 | 午夜精品久久久久久久99热浪潮 | 99在线啪| 日日摸夜夜骑 | 欧美成人精品一区二区三区 | 神马久久精品综合 | 欧美成人理论片乱 | 欧美成年性h版影视中文字幕 | 爽爽淫人综合网网站 | 蜜桃视频在线入口www | 一本在线高清码电影 | 黄色网址在线免费播放 | 欧美特黄一级高清免费的香蕉 | 大学生一级毛片在线视频 | 成人免费激情视频 | www.99av| 毛片a级毛片免费播放100 | av免费在线观看免费 | 欧美精品成人一区二区三区四区 | 九九精品在线观看视频 | 欧美成年性h版影视中文字幕 |