Learn how to develop jQuery plug-in with me (with a complete example and download)

Source: Internet
Author: User

Many front-end design developers in many companies are girls, and many of these girls have poor JavaScript skills. In front-end development, JavaScript skills are essential. So, if the front-end small MM is worrying about a JavaScript effect, you will go over and say to her, "Hi, beauty, use this. This is a jQuery plug-in I wrote ." I think your major events in your life will be quickly solved.
First think about what functions
This is the first step and an important step. Since we are just learning to write jQuery plug-ins, this function must be simpler. You don't need to take a bite to eat fat man. Let's try again. However, this function cannot be too boring. If it is boring and useless, even if it is done, it will be thrown into the toilet and will not be updated continuously, and it will not continue to improve.
My final choice is: beautify the table, make the table's parity line color different, then move the mouse over a row, a row can be highlighted. Simple and practical functions, good, good. Haha ~~
Don't rush to write, first think about the implementation principle
Not in a hurry. first think about the implementation principle. When necessary, first write a simple implementation prototype.
In my example of beautifying a table, the implementation principle is simple. It is nothing more than finding the odd and even rows of the table, and then adding different classes. It is also very easy to highlight the active row, as long as you determine the mouseover event, add a class and remove the class when mouseout.
A general framework
Before writing your own jQuery plug-ins, you should first study the plug-ins written by others. In fact, writing jQuery also basically has a general framework. All right, let's copy the framework. Copy codeThe Code is as follows: (function ($ ){
$. Fn. yourName = function (options ){
// Various attributes and Parameters
}
Var options = $. extend (defaults, options );
This. each (function (){
// Plug-in implementation code
});
};
}) (JQuery );

With this, we can set something in it.
Name, parameters, and attributes
It is difficult to start to enter the rivers and lakes, so you must have a loud name. Only when you walk on the rivers and lakes can you be awesome. Do not believe it. You have heard of the Chinese anti-Dental protection group "! Therefore, we must set up a loud name here. It must be simple, clear, and authoritative. Therefore, it is called "tableUI!
Parameters and attributes are also very simple. They are nothing more than the names of the three classes. It is called evenRowClass, oddRowClass, and activeRowClass.
So, the above frame will fill in the upper half.Copy codeThe Code is as follows: (function ($ ){
$. Fn. tableUI = function (options ){
Var defaults = {
EvenRowClass: "evenRow ",
OddRowClass: "oddRow ",
ActiveRowClass: "activeRow"
}
Var options = $. extend (defaults, options );
This. each (function (){
// Implementation code
});
};
}) (JQuery );

Here we will focus on this sentence:Copy codeThe Code is as follows: var options = $. extend (defaults, options );

In fact, it seems very embarrassing to merge multiple objects into one. Here, if you write a new parameter during the call, you will use your new parameter. If not, you will use the default parameter. For more information, please refer to jquery's official documentation: http://api.jquery.com/jQuery.extend/

Start the lower half
OK. You can fill the upper half. It is nothing more than finding the base and even rows (thanks to jQuery for providing a method similar to tr: even to make it simple), and then adding the corresponding class. Then, bind the mouseover and mouseout events to all the tr instances. The lower body code is as follows:Copy codeThe Code is as follows: (function ($ ){
$. Fn. tableUI = function (options ){
Var defaults = {
EvenRowClass: "evenRow ",
OddRowClass: "oddRow ",
ActiveRowClass: "activeRow"
}
Var options = $. extend (defaults, options );
This. each (function (){
Var thisTable = $ (this );
// Add the color of the parity row
$ (ThisTable). find ("tr: even"). addClass (options. evenRowClass );
$ (ThisTable). find ("tr: odd"). addClass (options. oddRowClass );
// Add the color of the active row
$ (ThisTable). find ("tr"). bind ("mouseover", function (){
$ (This). addClass (options. activeRowClass );
});
$ (ThisTable). find ("tr"). bind ("mouseout", function (){
$ (This). removeClass (options. activeRowClass );
});
});
};
}) (JQuery );

The most important step!
Some may think this is even done. On the contrary, the most important step is to write the plug-in name, version number, completion date, and author at the top of the plug-in, author's contact information, date of birth, Sanwei ...... And so on. This is because this plug-in is professional enough.Copy codeThe Code is as follows :/*
* TableUI 0.1
* Copyright (c) 2009 JustinYoung http://justinyoung.cnblogs.com/
* Date: 2010-03-30
* You can use tableUI to easily prompt you to use the table. The features provided in the first step show the color of the odd and even rows, highlighted by moving the mouse
*/
(Function ($ ){
$. Fn. tableUI = function (options ){
Var defaults = {
EvenRowClass: "evenRow ",
OddRowClass: "oddRow ",
ActiveRowClass: "activeRow"
}
Var options = $. extend (defaults, options );
This. each (function (){
Var thisTable = $ (this );
// Add the color of the parity row
$ (ThisTable). find ("tr: even"). addClass (options. evenRowClass );
$ (ThisTable). find ("tr: odd"). addClass (options. oddRowClass );
// Add the color of the active row
$ (ThisTable). find ("tr"). bind ("mouseover", function (){
$ (This). addClass (options. activeRowClass );
});
$ (ThisTable). find ("tr"). bind ("mouseout", function (){
$ (This). removeClass (options. activeRowClass );
});
});
};
}) (JQuery );

Demo address

Instance

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.