然而,你可以通過增加 call 和 apply 方法到 RegExp.prototype 中類似的現實這些方法 " /> 成人国产精品久久,成人在线视频网,久久99九九

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

js下函數般調用正則的方法附代碼

曾經 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 方法的執行可以跨瀏覽器。

if (!Array.prototype.filter) {
    // 返回一個數組,如果提供的過濾函數返回 true,則返回存在的數組中的元素。
    Array.prototype.filter = function (func, context) {
        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 方法,卻無法跨瀏覽器執行。

php技術js下函數般調用正則的方法附代碼,轉載需保留來源!

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

主站蜘蛛池模板: 陈宛蔚| 喂找谁呀 电影| 男娘曦曦呀曦曦最新| 浪荡女人米尔内1985| 黑玫瑰演员表| 寿比南山一般指多少岁| 夜之花电影| 音乐僵尸演员表| 猎魔人第三季 电视剧| 林蛟| 彭丹丹最惊艳的电影| 电视剧《绿萝花》| ctv5| 地球的宇宙环境教学反思| 羞羞片| 穿上触手内衣被调教堕落| 在屋顶上流浪| 条件概率经典例题| 操老女人视频| baekhyun| 山东教育电视台直播在线观看| 拾贝的小女孩阅读理解答案| 金太狼的幸福生活演员表_| 2014春节联欢晚会| 我爱你再见演员表| 美国伦理三颗熟樱桃| 建模软件| 今天上午拳王争霸赛直播| 带圈圈的序号1到30| 多少周开始做胎心监护| 老阿姨在等你免费播放47集电视剧完整| 哈利学前班| 四大名捕 电影| 周秀娜与罗仲谦新婚吻戏合集| 新红楼梦惊艳版| 金秀贤real| 阿尔法电影| 春江花月夜理解性默写及答案| 让我们一起摇太阳| 绿巨人2| 大学英语综合教程1答案|