开发者

trying to understand javascript Function.prototype

I trying to understand this piece of code

Function.prototype.method = function (name, fn) {
    this.pr开发者_JAVA技巧ototype[name] = fn;
    return this;
};

what does "this" refering to in the function body ? Is it refering to Function.prototype ? Is it trying to add a member to Function.prototype.prototype , namely Function.prototype.prototype[name] ?


Function in Function.prototype are called on Function instances.
Therefore, this refers to the function you called it on.

this.prototype would refer to the prototype of the function you called it on.

For example:

function MyClass() { }
MyClass.method("myMethod", function() { });

var c = new MyClass();
c.myMethod();    //MyClass.prototype.myMethod


"this" refers to the new function you have created on the right-hand side of the assignment statement.


>     Function.prototype.method = function (name, fn) {
>         this.prototype[name] = fn;
>         return this;
>     };

This means that functions inherit a method property from Function.prototype. e.g.

  function Foo(){}
  alert(typeof Foo.method); // function

When called as Foo.method() then within the method function, this will refer to Foo, so:

  Foo.method('sayHi', function(){alert('hi');});

creates a sayHi property of Foo.prototype and assigns it a value of the supplied function. Note that Foo doesn't inherit the function assigned by method, only objects created by Foo (i.e. instances of Foo) have the method.

Notes

A function's this keyword is set by the call, so if you call method some other way it will likely misbehave:

  var c = { method: Foo.method };
  alert(typeof c.method); // function

  c.method('sayHi', function(){alert('hi');}); // this.prototype is undefined


Function object vs Function instance object

First of all, in javascript, a function is also an object. From this, I mean not the object created by new () construct, but the function itself. To avoid confusion, I would refer such objects as Function object, and for object created using new () construct of a function as Function instance object.

_ proto _ and prototype properties

Any function object in javascript has two properties: _ proto _ and prototype. Moreover, any Function instance object (created using new constructor) has a property _ proto _ . The _ proto _ is what defines the inheritance. Some good resource on this could be found at

http://zeekat.nl/articles/constructors-considered-mildly-confusing.html

How is inheritance defined?

An object objA inherits another object objC if objA and objC are connected through any number of _ proto _ . So if objA has _ proto _ equal to objB, and objB has _ proto _ equal to objC, then objA inherits objB and objC, while objB inherits objC.

What is meant by inheritance?

It means any inheriting object can use any property of inherited object.

What is Function.prototype

It is the object whom _ proto _ of every function object refers. This means every Function object has access to properties of Function.prototype, since every Function object inherits Function.prototype object. This also means that if method property is added to Function.prototype object, it would be available to all the possible Function objects in javascript. This includes Strings, Number, etc.

this.prototype[name] = func;

'this' refers to Function object when the 'method' is invoked from Function objects like Number, String, etc. Which means that we now have a new property in Function object with name "name", and its a function 'func'.

What good is prototype property of Function object

A function object's prototype is referred to by the Function instance object's _ proto _ created using that function's new construct.

If the following was executed:

Number.method('integer', function () {...});

then Number.prototype has that integer method defined in it. This means each Number function instance object, e.g. new Number (2.4), would "inherit" this new property 'integer' from Number.prototype, since that Number function instance object would have its _ proto _ set to Number.prototype.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜