您好,今天是: ·加入收藏·设为首页·联系站长
洛歌教程网--本站提供(PS教程)
站内搜索:
当前位置:洛歌教程网 >> 网站建设 >> JavaScript技术应用 >> 浏览文章  
javascript扩展:正则像函数一样调用
作者:admin 来源:网络 文章点击数:

原文地址:《Regular Expressions As Functions》

Firefox 包含了一个非标准的 javascript 扩展,使正则像函数一样可调用。这为调用正则的 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 方法的执行可以跨浏览器。

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




人支持

发表评论】【告诉好友】【打印此文】【收藏此文】【关闭窗口
  最新文章
  热门文章
  推荐文章

| 设为首页 | 加入收藏 | 关于本站 | 联系站长 | 友情链接 | 版权申明 | 雁过留声 |

Copyright◎ 2003-2007 www.logooe.com All Rights Reserved Contact us

Email:liyushuai755#163.com QQ:65557616

版权归作者所有,如果无意中侵犯了您的版权,请来信告知,本站将再3个工作日内删除。

备案序号:琼ICP备06003564号

 


Free

本站(洛歌教程网)提供如下信息:PS教程,PhotoShop教程,SoftImage 3D教程,AutoCAD教程,maya教程,3ds max教程,平面设计欣赏,ImageReady教程,Illustrator教程,Coreldraw教程,Flash教程,freehand教程,fireworks教程,图像辅助