一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

js函數(shù)般調(diào)用正則

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

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

注意上面的兩個(gè)方法完全忽略 context 參數(shù),你可以提交 null 或者 任何其他作為 context 的對(duì)象,并且你將會(huì)類似的得到正則 exec 方法的返回值。使用上面的方法,無(wú)論在什么情況下,使我們正常地使用正則表達(dá)式和函數(shù)變得容易得多。一些很明顯的例子,比如這些在 JavaScript 1.6 的數(shù)組迭代中很有用。下面的 filter, every, some, 和 map 方法的執(zhí)行可以跨瀏覽器。
復(fù)制代碼 代碼如下:
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 ,如果數(shù)組中的每個(gè)元素滿足提供的測(cè)試函數(shù)。
    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,如果數(shù)組中至少有一個(gè)元素滿足提供的測(cè)試函數(shù)。
    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) {
    // 返回一個(gè)數(shù)組,現(xiàn)有數(shù)組中的每個(gè)元素調(diào)用提供的函數(shù)的返回值。
    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;
    };
}

因?yàn)閑xec 方法返回?cái)?shù)組或 null 值,并會(huì)恰當(dāng)?shù)念愋娃D(zhuǎn)換為 true 和 false,上面的代碼允許我們像這樣使用:[”a”,”b”,”ab”,”ba”].filter(/^a/),返回所有以“a”開(kāi)始的值:[”a”,”ab”]。

確實(shí),在 Firefox 中已經(jīng)實(shí)現(xiàn)了 Array.prototype.filter ,由于 exec 的間接調(diào)用已經(jīng)在該瀏覽器中起作用了。但是如果 filter 沒(méi)有添加 RegExp.prototype.call 方法,卻無(wú)法跨瀏覽器執(zhí)行。

JavaScript技術(shù)js函數(shù)般調(diào)用正則,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 精品热久久 | 一区二区三区视频观看 | 国产精品亚洲欧美一区麻豆 | 五月激情婷婷综合 | 亚洲午夜久久久久久噜噜噜 | 成人久久免费视频 | 欧美激情在线免费 | 一区二区三区在线观看视频 | 一区二区三区免费 | 亚洲网美女 | 婷婷97狠狠的狠狠的爱 | 精品国免费一区二区三区 | aⅴ一区二区三区无卡无码 aaaaaa精品视频在线观看 | 91视频福利 | 看全色黄大色黄大片视频 | 精品久久天干天天天按摩 | 激情五月视频 | 女人夜色黄网在线观看 | 99久久精品免费看国产高清 | 亚洲区在线播放 | 免费特黄视频 | 手机在线黄色网址 | 国产免费久久精品丫丫 | 娇小videosbest8另类| 91精品国产自产91精品 | 日本免费一区二区视频 | 国模青青丰满人体大尺度展示 | 中文字幕久久久久久精 | 国产精品福利午夜h视频 | 色播六月 | 国产精品视频2021 | 桃花综合久久久久久久久久网 | 六月婷婷综合网 | 国产高清91| 亚洲天码中文字幕第一页 | 亚洲香蕉网久久综合影院3p | 国产福利最新手机在线观看 | 五月天激情播播 | 伊色综合久久之综合久久 | 国产精品久久久亚洲456 | 国产高清自拍 |