js函数般调用正则
JS 函数 调用 正则
2023-06-13 09:14:00 时间
这为调用正则的
然而,你可以通过增加
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方法的返回值。使用上面的方法,无论在什么情况下,使我们正常地使用正则表达式和函数变得容易得多。一些很明显的例子,比如这些在JavaScript1.6的数组迭代中很有用。下面的
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 方法,却无法跨浏览器执行。
相关文章
- 用JS打印三角形_用java打印倒三角
- 重学JS-8-函数作用域、闭包
- JS map()方法:对数组的每个元素调用指定的回调函数
- 使用隐藏框架加载远程JS脚本(调用远程函数)
- Vue.js是什么?它有什么特点?
- filemanage功能中用到的lib.js
- js下函数般调用正则的方法附代码
- js动态添加标签(新增一行,其实很简单,就是几个函数的应用)
- js打印纸函数代码(递归)
- js编程笔记无名函数
- iframe子父页面调用js函数示例
- JS版的date函数(和PHP的date函数一样)
- javascript写的异步加载js文件函数(支持数组传参)
- 使用JS实现jQuery的addClass,removeClass,hasClass函数功能
- setinterval()与clearInterval()JS函数的调用方法
- js匿名函数的调用示例(形式多种多样)