Jquery中$與$.fn的區別

來源:互聯網
上載者:User

      當今web開發往往離不開Jquery的使用,Jquery以其簡潔的使用方式、良好的瀏覽器安全色性贏得了軟體研發同行的青睞,作為其中的一員,自然也不例外,儘管剛開始時很排斥Jquery,今天我談一下對Jquery中$與$.fn的認識和理解,不對地方深望指正:

       1、什麼是$?

         答:jquery的另一種表現形式;

        2、看下面的例子:

              例子01:

                           <html>
                                  <head>
                                               <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
                                               <title>$與$.fn的區別——demo 01</title>
                                               <script type="text/javascript" src="./jquery-1.6.2.js"></script>
                                               <script type="text/javascript">
                                                        $.test = function(a,b) {
                                                                  return a+b;
                                                        };
                                                       alert($.test(4,4));
                                         </script>
                                 </head>
                                 <body>
                                 </body>
                        </html>
          例子02:

                        <html>
                              <head>
                                         <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
                                         <title>$與$.fn的區別——demo 02</title>
                                         <script type="text/javascript" src="./jquery-1.6.2.js"></script>
                                         <script type="text/javascript">
                                                    $.extend({
                                                             test:function(a,b) {
                                                                   return a+b;
                                                             }
                                                   });
                                                  alert($.test(4,4));
                                        </script>
                             </head>
                             <body>
                            </body>
                     </html>

            上面兩個例子中的黃色背景出的代碼有什麼不同和相同?

         答:除了功能相同以外最大的相同點在於調用函數(或方法)的方式相同;上面兩個例子最大的不同點在於聲明建立test方法的方式不同。

    3、看下面的例子:

        例子03:

                   <html>
                            <head>
                                  <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
                                  <title>$與$.fn的區別——demo 03</title>
                                  <script type="text/javascript" src="./jquery-1.6.2.js"></script>
                                  <script type="text/javascript">
                                           $.fn.test = function() {
                                                     return $(this).val();
                                          };
                                          $(function(){
                                                     alert($("#name").test());
                                         });
                                </script>
                          </head>
                          <body>
                                <input type="hidden" id="name" name="name" value="高煥傑"/>
                          </body>
                    </html>

         例子04:

                   <html>
                         <head>
                                <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
                                <title>$與$.fn的區別——demo 04</title>
                               <script type="text/javascript" src="./jquery-1.6.2.js"></script>
                               <script type="text/javascript">
                                     $.fn.extend({ 
                                                  test:function() {
                                                          return $(this).val();
                                                 }
                                    });
                                    $(function(){
                                                 alert($("#name").test());
                                    });
                             </script>
                      </head>
                      <body>
                              <input type="hidden" id="name" name="name" value="高煥傑"/>
                      </body>
                 </html>

         上面兩個例子中的綠色背景出的代碼有什麼不同和相同?

         答:除了功能相同以外最大的相同點在於調用函數(或方法)的方式相同;上面兩個例子最大的不同點在於聲明建立test方法的方式不同。

      4、Jquery中$與$.fn的區別是什嗎?

         答:在回答這個問題以前,需要明白一個事實:Jquery的方法是可以拓展的,上面這4個例子都是對Jquery方法的拓展,從調用聲明建立方法的方式來看,可以歸結為兩類:一類直接由$符調用;另一類由$("")來調用,說到這裡你是不是想到了Java語言中的靜態方法和執行個體方法,是的,如果從java類的角度認識調用建立的Jquery方法可能更好理解些,儘管Javascript沒有明確的類的概念。好了現在可以回答問題了:$拓展的方法是靜態方法,可以使用$直接調用,其拓展的方式有兩種,一般使用$.extend({});;而$.fn拓展的方法是執行個體方法,必須由“對象”$("")來調用,其拓展的方式同樣有兩種,一般使用$.fn.extend({ })。

   5、知識延展,究竟什麼是fn?

    答:同樣在回答這樣一個問題以前請開啟一個Jquery檔案(0分下載) 搜尋這樣一個字元“jQuery.prototype”,告訴我你看到了什麼:jQuery.fn = jQuery.prototype = {......},嗯嗯,或許你已經猜到了——fn就是prototype,是這樣嗎?請看下面的兩個例子:

    例子05:

         <html>
           <head>
               <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
               <title>$與$.fn的區別——demo 05</title>
               <script type="text/javascript" src="./jquery-1.6.2.js"></script>
               <script type="text/javascript">
                      $.prototype.test = function() {
                           return $(this).val();
                      };
                      $(function(){
                           alert($("#name").test());
                      });
              </script>
         </head>
          <body>
              <input type="hidden" id="name" name="name" value="高煥傑"/>
          </body>
       </html>

   例子06:

       <html>
          <head>
              <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
              <title>$與$.fn的區別——demo 06</title>
              <script type="text/javascript" src="./jquery-1.6.2.js"></script>
              <script type="text/javascript">
                   $.prototype.extend({ 
                           test:function() {
                               return $(this).val();
                           }
                   });
                   $(function(){
                           alert($("#name").test());
                   });
              </script>
        </head>
        <body>
              <input type="hidden" id="name" name="name" value="高煥傑"/>
        </body>
     </html>

     上面兩個例子通過將fn改為prototype以後可以運行,呵呵呵,你猜對了。

     0分下載demo:Jquery中$與$.fn的區別執行個體.zip

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.