jquery外掛程式製作教程 txtHover

來源:互聯網
上載者:User

定義外掛程式的結構骨架:
  書中最開始使用的結構骨架如下:
複製代碼 代碼如下:
jQuery.fn.fluginmane=function(){
  return this.each(function(){
    //code...
  })
}  

這種結構不是很理想,特別書中提到,為了防止衝突例子不使用$,而使用jQuery。在這裡,我們使用匿名函數的方式實現外掛程式的結構骨架,這樣就可以防止可能的衝突。也希望大家好好瞭解下匿名函數相關的知識。
複製代碼 代碼如下:
(function($){
  $.fn.fluginname=function(){
    return this.each(function(){
      //code...
    });
  }
})(jQuery);

注意點:
  1.為了統一和規範,我們的外掛程式檔案都將以jquery.fluginname.js的形式命名(fluginname代表你外掛程式的名字)。
  2.我們使用到的函數都需要是私人的,不能被外部存取到,這樣可保證外掛程式不會受到外部的影響和幹擾(匿名函數已經保證了這點)。
  3.允許使用者使用options控制外掛程式的行為。
  4.預設的options允許外部存取,這樣使用者就可以用最少的代碼實現自訂化。
  5.this.each()會遍曆所有符合要求的對象,他本身是個jquery對象,外掛程式最後返回該對象。其實通過這種方式就實現了javascript的鏈式模式。
我們的第一個外掛程式:txtHover
  1.代碼實現:
複製代碼 代碼如下:
(function($){
  $.fn.txtHover=function(){
    return this.each(function(){
      $(this).text('text changed!');
    });
  }
})(jQuery);

2.如何使用:
  建立一個html檔案,添加jquery和外掛程式的引用,代碼如下:
複製代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript" src="Scripts/jquery-1.4.1.min.js"></script>
<script type="text/javascript" src="Scripts/jquery.txtHover.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$('#test').txtHover();
});
</script>
</head>
<body>
<div id="test">
this is test.</div>
</body>
</html>

添加hover事件:
複製代碼 代碼如下:
(function ($) {
$.fn.txtHover = function () {
return this.each(function () {
var temp = $(this).text();
$(this).hover(function () {
$(this).text('text changed!');
}, function () {
$(this).text(temp);
});
});
}
})(jQuery);  

第一個版本,當頁面載入完畢之後,div的內容就被修改了,這樣的設計沒多大用處。我們最常用到的是,當滑鼠移到到文字上面的時候產生一些變化。改進的外掛程式添加了hover事件。首先我們把div的原始值儲存在變數temp裡面,當滑鼠移動到div上面的時候,文字被替換,滑鼠移出時,將文字替換回來。
添加自訂選項
  為了方便使用者更加靈活的使用,我們需要添加自訂的功能,外掛程式代碼修改:
複製代碼 代碼如下:
(function ($) {
$.fn.txtHover = function (options) {
var defaults = { txt: 'text changed!' };
var opt = $.extend(defaults, options);
return this.each(function () {
var self = $(this);
var temp = self.text();
self.hover(function () {
self.text(opt.txt);
}, function () {
self.text(temp);
});
});
}
})(jQuery);  

外掛程式定義了一個變數defaults,設定了預設的文字資訊。我們使用$.extend()(不瞭解這個函數的朋友可以去查閱資料)方法擴充了一個新變數opt,如果使用者傳入的options變數包含txt,則opt就使用使用者傳入的,否則就使用系統預設的。我們在系統中定義了 var self = $(this),來代替this對象。this在javascript中是個很惱人的對象,在不同函數上下文中所代表的對象會不同,將this傳給一個另外的變數會避免程式出現一些錯誤。不熟悉的朋友很有必要好好掌握該知識點。
  使用者在html頁面上調用外掛程式的時候,可以自訂滑鼠移到div上面時候的文字內容了。
$(document).ready(function () {
  $('#test').txtHover({ txt: 'test' });
});  好了,今天的例子到此為止。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.