zoukankan      html  css  js  c++  java
  • 小议jQuery插件开发

        1.写在前面

      大家都知道PHP专注后台与数据库的交互,前端页面中是js的天下,而jQuery作为使用最广泛,最简单有效的js的框架。深受大家的喜欢。

      而js作为一门面向对象的开发语言,它独特的语法和函数式的写法,也是妙趣横生。使用jQuery进行插件的开发,就能将一些js的函数封装在一个对象中,并对其扩展,提高了开发的效率,体现了面向对象的优越性。

        2.下面是正题

      主要有两种形式的jQuery的插件形式: 

      1)对象的形式扩展插件 $.fn.extend 

      2)函数的形式扩展插件 $.extend

      这里我们直接给出两个例子:

      1)对象形式的插件实现的功能是 鼠标点击Input输入框时,弹出其Value值

      2)函数形式的插件实现的功能是 鼠标移出Input输入框时,弹出其title值

      大家可以仔细揣摩,两者的不同,在此基础上,写出功能更强大,更健壮的jQuery的插件

      代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    </head>
    <body>
    <input id="input" name="name" value="我喜欢jQuery" title="我喜欢js">
    <script src="http://www.eol.cn/js/global/jQuery_latest.min.js">
    </script>
    <script>

    /*************编写插件***********/

    /*

    *1. 对象的形式扩展插件 $.fn.extend   调用 $("#idname").functionName();

    */
    (function($){
          $.fn.extend({
            showVal : function(){
               var $this = $(this);
               $this.click(function () {//点击时显示里面的数值
                   alert($this.val());
                   
               })
               
       }
        

    })(jQuery); 

    //

    /*

    *2. 函数的形式扩展插件 $.extend   调用 $.functionName();

    */


          $.extend({
            showTitle : function(){
               
               $('#input').mouseout(function () {//鼠标移出时弹窗
                  var $this = $(this);
                   alert($this.attr('title'));
                   
               })

       }
        

    })

    })(jQuery)


    $(function(){

    $("#input").showVal();//1. 对象的形式扩展插件 $.fn.extend   调用 $("#idname").functionName();
    $.showTitle();//2. 函数的形式扩展插件 $.extend   调用 $.functionName();

    })
    </script>
    </body>
    </html>

    总结:

    jQuery为开发插件提拱了两个方法,分别是:

    jQuery.fn.extend(object);  给jQuery对象添加方法。
    jQuery.extend(object);  为扩展jQuery类本身.为类添加新的方法。

    1) jQuery.fn.extend(object);

    fn 是什么东西呢。查看jQuery代码,就不难发现。

    jQuery.fn = jQuery.prototype = {  

    init: function( selector, context ) {//....   

    //......  

    };   

    原来 jQuery.fn = jQuery.prototype.对prototype肯定不会陌生啦。虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便。jQuery便是一个封装得非常好的类,比如我们用 语句 $("#input") 会生成一个 jQuery类的实例。

    jQuery.fn.extend(object); 对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。

    上面的列子中 $("#input") 为一个jQuery实例,当它调用成员方法 showVal()后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。

    2) jQuery.extend(object); 

    为jQuery类添加添加类方法,可以理解为添加静态方法。如:

    $.extend({  

        add:function(a,b){return a+b;}  

    });  

    便为 jQuery 添加一个为 add 的 “静态方法”,之后便可以在引入 jQuery 的地方,使用这个方法了,$.add(3,4); //return 7

     

     

    by  djp

  • 相关阅读:
    android studio 提示翻译
    mysql-You can’t specify target table for update in FROM clause错误
    echarts-案例
    maven-过滤不打入包的文件
    neo4j关闭和开启密码访问权限
    linux-crontab定时任务
    neo4j-备份、恢复
    windows和linux执行class
    mvn-打jar运行包(含环境变量配置)
    mysql-netstat
  • 原文地址:https://www.cnblogs.com/newbalanceteam/p/4984928.html
Copyright © 2011-2022 走看看