源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

js函数般调用正则

  • 时间:2021-02-15 17:00 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:js函数般调用正则
这为调用正则的 [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:RegExp:exec]exec[/url] 方法提供了便捷。例如,在 Firefox中,regex(”string”) 等同于 regex.exec(”string”)。曾经 ECMAScript 4 建议指出这个功能将会增加到 ES4 规范中,但后来的在 [url=https://mail.mozilla.org/listinfo/es4-discuss]ES4-discuss mailing list[/url] 的讨论中,这个建议可能被废除。 然而,你可以通过增加 [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Function:call]call[/url] 和 [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Function:apply]apply[/url] 方法到 RegExp.prototype 中类似的现实这些方法。既有助于功能设计,又可实现对函数和正则表达式均有效的隐藏类型(duck-typed )代码。因此,让我们增加这些方法。
[url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Array:filter]filter[/url], [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Array:every]every[/url], [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Array:some]some[/url], 和 [url=http://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Global_Objects:Array:map]map[/url] 方法的执行可以跨浏览器。
[u]复制代码[/u] 代码如下:
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 方法,却无法跨浏览器执行。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部