天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

js函數般調用正則

這為調用正則的 exec 方法提供了便捷。例如,在 Firefox中,regex(”string”) 等同于 regex.exec(”string”)。曾經 ECMAScript 4 建議指出這個功能將會增加到 ES4 規范中,但后來的在 ES4-discuss mailing list 的討論中,這個建議可能被廢除。

然而,你可以通過增加 call 和 apply 方法到 RegExp.prototype 中類似的現實這些方法。既有助于功能設計,又可實現對函數和正則表達式均有效的隱藏類型(duck-typed )代碼。因此,讓我們增加這些方法。
復制代碼 代碼如下:
RegExp.prototype.call = function (context, str) {
    return this.exec(str);
};
RegExp.prototype.apply = function (context, args) {
    return this.exec(args[0]);
};

注意上面的兩個方法完全忽略 context 參數,你可以提交 null 或者 任何其他作為 context 的對象,并且你將會類似的得到正則 exec 方法的返回值。使用上面的方法,無論在什么情況下,使我們正常地使用正則表達式和函數變得容易得多。一些很明顯的例子,比如這些在 JavaScript 1.6 的數組迭代中很有用。下面的 filter, every, some, 和 map 方法的執行可以跨瀏覽器。
復制代碼 代碼如下:
var results = [];
        for (var i = 0; i < this.length; i++) {
            if (i in this && func.call(context, this[i], i, this))
            results.push(this[i]);
        }
        return results;
    };
}

if (!Array.prototype.every) {
    // 返回 true ,如果數組中的每個元素滿足提供的測試函數。
    Array.prototype.every = function (func, context) {
        for (var i = 0; i < this.length; i++) {
            if (i in this && !func.call(context, this[i], i, this))
            return false;
        }
        return true;
    };
}

if (!Array.prototype.some) {
    // 返回 true,如果數組中至少有一個元素滿足提供的測試函數。
    Array.prototype.some = function (func, context) {
        for (var i = 0; i < this.length; i++) {
            if (i in this && func.call(context, this[i], i, this))
            return true;
        }
        return false;
    };
}

if (!Array.prototype.map) {
    // 返回一個數組,現有數組中的每個元素調用提供的函數的返回值。
    Array.prototype.map = function (func, context) {
        var results = [];
        for (var i = 0; i < this.length; i++) {
            if (i in this)
            results[i] = func.call(context, this[i], i, this);
        }
        return results;
    };
}

因為exec 方法返回數組或 null 值,并會恰當的類型轉換為 true 和 false,上面的代碼允許我們像這樣使用:[”a”,”b”,”ab”,”ba”].filter(/^a/),返回所有以“a”開始的值:[”a”,”ab”]。

確實,在 Firefox 中已經實現了 Array.prototype.filter ,由于 exec 的間接調用已經在該瀏覽器中起作用了。但是如果 filter 沒有添加 RegExp.prototype.call 方法,卻無法跨瀏覽器執行。

JavaScript技術js函數般調用正則,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 99草在线观看 | 午夜伦理在线观看 | 国产在线综合色视频 | 亚洲欧美偷拍视频一区 | 伊人久久99热这里只有精品 | 西西人体一级裸片 | 国产精品美女久久久久浪潮AV | 野花香在线观看免费观看大全动漫 | 成人在线观看免费视频 | 性女传奇 快播 | 色偷偷av男人的天堂 | 久久精品视频16 | YELLOW在线观看高清视频免费 | 99久视频只有精品2019 | 99久久99久久精品国产片果冻 | 欧美大片xxxxbbbb | 肉动漫3D卡通无修在线播放 | 在线免费观看成年人视频 | 丁香成人网址 | 91热久久免费频精品动漫99 | 嫩草影院在线观看精品视频 | 在线观看国产人视频免费中国 | 久久re视频这里精品09首页 | 无码AV熟妇素人内射V在线 | 亚洲免费综合色视频 | 99视频福利| 国产一级特黄aa毛片 | 亚洲精品高清中文字幕完整版 | 久久久精品3d动漫一区二区三区 | 亚洲国产免费观看视频 | 中国农村妇女真实BBWBBWBBW | 国产热久久精 | 国产免费人成在线视频有码 | 国产精品久久久久久影院 | 麻豆精品传媒2021网站入口 | 色老汉网址导航 | 美女也烦恼主题曲 | 精品极品三大极久久久久 | 色婷婷国产精品视频一区二区三区 | 99在线在线视频观看 | 中文字幕高清在线观看 |