- 原版本文章理解有误,现已初步更正 *
Generics 在很多程序设计语言中都被称之为 「泛型」 ,而 Javascript 为动态类型的语言,所以称为「一般化」更为合适些。
在 Javascript 的对象模型中,函数(Function)也是对象的一种。顶层函数同时可以通过 call 和 apply 调用不属于对象自身的方法。
同时,Javascrpt 中有很多对象都会有相同的属性,比如 nodeList、Array、arguments 都有 length 属性,都可以使用下标(比如 arguments[0])。
考虑 forEach 的实现( 详细 )
if (!Array.prototype.forEach) {
Array.prototype.forEach = function(func) {
var len = this.length;
if (typeof func != "function") {
throw new TypeError();
}
var thisp = arguments[1];
for (var i = 0; i < len; i++) {
if (i in this) {
func.call(thisp, this[i], i, this);
}
}
};
}
根据上述的代码可以看到,虽然其为 Array 对象的方法,但函数内部仅仅调用了 this 的 length(this.length) 和 下标(this[i])两个属性。那么,期前举到的例子中,nodeList 以及 arguments 也可以应用于此函数(方法):
[].forEach.call(document.getElementsByTagName('li'), function() {...});
或者
Array.prototype.foreach.call(document.getElementsByTagName('li'), function() {...});
上面的 forEach 函数就被称之为 Generic 函数(A generic function)。下面是 ECMAScript 规范中,有关 Generices 的描述
A generic function is a function object that performs run-time dispatch to
one of several attached methods based on the actual types of the argument
values and the signatures of the available methods.
Generic 有很多的用处,对象只要支持被调用函数所需要调用的属性,就可以复用,而不需要了解此函数针对的对象类型是什么。比如,上述的 Array.forEach 虽然针对的是 Array 对象,但是仍然可以针对 nodeList 工作得很好。
其实在 ECMAScript 规范 中,定义了很多 generic 函数。以上述的 Array 对象为例,join、indexOf、lastIndexOf、forEach、map、filter、some、every 等都为 generic 函数,这可以在我们以后的编程中会很方便。
--Split--
感谢 lifesinger 兄 的解释
JavaScript 中方法分为 Generic method 和 Instance method。 Instance method,依附在实例上的方法,翻译为实例方法。Generic method,直接依附于对象上,与实例方法相比较,可以称为泛化方法。
Generic 可以翻译成 泛化
JavaScript中方法分为Generic method 和 Instance method.
Instance method, 依附在实例上的方法,实例方法
Generic method, 直接依附于对象上,与实例方法相比较,可以称为泛化方法
[...]很明显,上面的题目有可能还是无法说明本篇文章的题目。泛型(Generic)应用其实 期前也说明过,但这里主要说明 Array 方法对于“类数组”的操作使用。[...]