jquery插件制作教程 txtHover
2024-05-06 14:21:22
供稿:網友
定義插件的結構骨架:
書中最開始使用的結構骨架如下:
代碼如下:
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上面的時候,文字被替換,鼠標移出時,將文字替換回來。