jQuery.fn = jQuery.prototype = {
//list of functions available to the jQuery api
}
But the real tool behind fn is its availability to hook your own functionality into jQuery. Remember that jquery will be the parent scope to your function, so this will refer to the jquery object.
$.fn.myExtension = function(){
var currentjQueryObject = this;
//work with currentObject
return this;//you can include this if you would like to support chaining
};
So here is a simple example of that. Lets say I want to make two extensions, one which puts a blue border, and which colors the text blue, and I want them chained.
In jQuery, the fn property is just an alias to the prototype property.
The jQuery identifier (or $) is just a constructor function, and all instances created with it, inherit from the constructor's prototype.
A simple constructor function:
function Test() {
this.a = 'a';
}
Test.prototype.b = 'b';
var test = new Test();
test.a; // "a", own property
test.b; // "b", inherited property
A simple structure that resembles the architecture of jQuery:
(function() {
var foo = function(arg) { // core constructor
// ensure to use the `new` operator
if (!(this instanceof foo))
return new foo(arg);
// store an argument for this example
this.myArg = arg;
//..
};
// create `fn` alias to `prototype` property
foo.fn = foo.prototype = {
init: function () {/*...*/}
//...
};
// expose the library
window.foo = foo;
})();
// Extension:
foo.fn.myPlugin = function () {
alert(this.myArg);
return this; // return `this` for chainability
};
foo("bar").myPlugin(); // alerts "bar"
In the jQuery source code we have jQuery.fn = jQuery.prototype = {...} since jQuery.prototype is an object the value of jQuery.fn will simply be a reference to the same object that jQuery.prototype already references.
To confirm this you can check jQuery.fn === jQuery.prototype if that evaluates true (which it does) then they reference the same object
fn
literally refers to the jqueryprototype
.This line of code is in the source code:
But the real tool behind
fn
is its availability to hook your own functionality into jQuery. Remember that jquery will be the parent scope to your function, sothis
will refer to the jquery object.So here is a simple example of that. Lets say I want to make two extensions, one which puts a blue border, and which colors the text blue, and I want them chained.
jsFiddle Demo
Now you can use those against a class like this:
(I know this is best done with css such as applying different class names, but please keep in mind this is just a demo to show the concept)
This answer has a good example of a full fledged extension.
jQuery.fn
is defined shorthand forjQuery.prototype
. From the source code:That means
jQuery.fn.jquery
is an alias forjQuery.prototype.jquery
, which returns the current jQuery version. Again from the source code:In jQuery, the
fn
property is just an alias to theprototype
property.The
jQuery
identifier (or$
) is just a constructor function, and all instances created with it, inherit from the constructor's prototype.A simple constructor function:
A simple structure that resembles the architecture of jQuery:
In the jQuery source code we have
jQuery.fn = jQuery.prototype = {...}
sincejQuery.prototype
is an object the value ofjQuery.fn
will simply be a reference to the same object thatjQuery.prototype
already references.To confirm this you can check
jQuery.fn === jQuery.prototype
if that evaluatestrue
(which it does) then they reference the same object