JavaScript扩展:正则像函数一样调用

2016-02-20 00:45 3 1 收藏

今天图老师小编给大家展示的是JavaScript扩展:正则像函数一样调用,精心挑选的内容希望大家多多支持、多多分享,喜欢就赶紧get哦!

【 tulaoshi.com - Web开发 】

原文地址:《Regular Expressions As Functions》

Firefox 包含了一个非标准的 JavaScript 扩展,使正则像函数一样可调用。这为调用正则的 exec 方法提供了便捷。例如,在 Firefox中,regex(string) 等同于 regex.exec(string)。曾经 ECMAScript 4 建议指出这个功能将会增加到 ES4 规范中,但后来的在 ES4-discuss mailing list 的讨论中,这个建议可能被废除。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

然而,你可以通过增加 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 方法的执行可以跨浏览器。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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 方法,却无法跨浏览器执行。

来源:https://www.tulaoshi.com/n/20160220/1632485.html

延伸阅读
蔓越梅芝士蛋糕 准备工作:提前将奶油奶酪取出切小块,放至室温软化。 制作方法: 1.将消化饼干扳成碎块。 2.放入搅拌机内,搅拌成碎屑状。 3.将切成碎块的黄油放入不锈钢碗内,小锅内烧水至60度,将碗放在锅上,隔水加热至溶化成液态。 4.将溶化的黄油倒入饼干屑中拌匀。 5.将拌好的饼干屑装入模具底部,用汤匙压平整,...
菠菜海绵蛋糕面包 将除黄油以外的其他材料,放在一起揉成面团,再把黄油加入,慢慢揉进面团,至面团能拉出薄膜,放到温暖湿润处进行第一次发酵至原来2.5-3倍大 发酵好的面团取出,排去大部分空气,滚圆,盖湿布松弛15分钟 松弛好的面团,用手掌压扁,并用擀面杖擀到与8寸蛋糕模一样大小,把擀好的面饼铺到8寸模底(模具中刷油),蒸锅烧...
标签: Web开发
1、在JavaScript中调用Flex(ActionScript)方法 在Flex中可以用ExternalInterface来调用Flex的方法。 在Flex应用中通过调用addCallback()可以把一个方法添加到列表中。addCallback将一个ActionScript的方法注册为一个JavaScript和VBScript可以调用的方法。 ddCallback()函数的定义如下: addCallback(function_name:String, closure:Functio...
标签: 电脑入门
下面的几个技巧主要改变的是使用电脑时最常遇到的一些项目。 1.找回XP风格的开始菜单 右击Vista开始按钮,从弹出的右键菜单中选择属性项,选中传统开始菜单项,最后单击确定即可。这样Vista的开始菜单就又变回 XP系统 的风格,用起来顺手多了。 图1 Vista和XP风格开始菜单比较(图注:Vista的开始菜单,改为在同一窗口中层层打开下级菜...
幸福像花儿一样正宗做法/图解/步骤: 1. 我的这款饼干面团揉好不必冷藏,直接操作烘烤就可以,成品很平整酥脆,适合做糖霜饼干底,黄油加白砂糖打发至蓬松 2. 分次少量加入蛋液,每次加完蛋液搅拌至完全融合再加下一次,直到加完 3. 搅拌好的样子 4. 筛入面粉,翻拌均匀 5. 用手捏成团 6. ...

经验教程

197

收藏

94
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部