jquery插件制作教程 txtHover
書中最開始使用的結(jié)構(gòu)骨架如下:
jQuery.fn.fluginmane=function(){
return this.each(function(){
//code...
})
}
這種結(jié)構(gòu)不是很理想,特別書中提到,為了防止沖突例子不使用$,而使用jQuery。在這里,我們使用匿名函數(shù)的方式實(shí)現(xiàn)插件的結(jié)構(gòu)骨架,這樣就可以防止可能的沖突。也希望大家好好了解下匿名函數(shù)相關(guān)的知識。
(function($){
$.fn.fluginname=function(){
return this.each(function(){
//code...
});
}
})(jQuery);
注意點(diǎn):
1.為了統(tǒng)一和規(guī)范,我們的插件文件都將以jquery.fluginname.js的形式命名(fluginname代表你插件的名字)。
2.我們使用到的函數(shù)都需要是私有的,不能被外部訪問到,這樣可保證插件不會(huì)受到外部的影響和干擾(匿名函數(shù)已經(jīng)保證了這點(diǎn))。
3.允許用戶使用options控制插件的行為。
4.默認(rèn)的options允許外部訪問,這樣用戶就可以用最少的代碼實(shí)現(xiàn)自定義化。
5.this.each()會(huì)遍歷所有符合要求的對象,他本身是個(gè)jquery對象,插件最后返回該對象。其實(shí)通過這種方式就實(shí)現(xiàn)了javascript的鏈?zhǔn)侥J健?
我們的第一個(gè)插件:txtHover
1.代碼實(shí)現(xiàn):
(function($){
$.fn.txtHover=function(){
return this.each(function(){
$(this).text('text changed!');
});
}
})(jQuery);
2.如何使用:
創(chuàng)建一個(gè)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);
第一個(gè)版本,當(dāng)頁面加載完畢之后,div的內(nèi)容就被修改了,這樣的設(shè)計(jì)沒多大用處。我們最常用到的是,當(dāng)鼠標(biāo)移到到文字上面的時(shí)候產(chǎn)生一些變化。改進(jìn)的插件添加了hover事件。首先我們把div的原始值保存在變量temp里面,當(dāng)鼠標(biāo)移動(dòng)到div上面的時(shí)候,文字被替換,鼠標(biāo)移出時(shí),將文字替換回來。
添加自定義選項(xiàng)
為了方便用戶更加靈活的使用,我們需要添加自定義的功能,插件代碼修改:
(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);
插件定義了一個(gè)變量defaults,設(shè)置了默認(rèn)的文字信息。我們使用$.extend()(不了解這個(gè)函數(shù)的朋友可以去查閱資料)方法擴(kuò)展了一個(gè)新變量opt,如果用戶傳入的options變量包含txt,則opt就使用用戶傳入的,否則就使用系統(tǒng)默認(rèn)的。我們在系統(tǒng)中定義了 var self = $(this),來代替this對象。this在javascript中是個(gè)很惱人的對象,在不同函數(shù)上下文中所代表的對象會(huì)不同,將this傳給一個(gè)另外的變量會(huì)避免程序出現(xiàn)一些錯(cuò)誤。不熟悉的朋友很有必要好好掌握該知識點(diǎn)。
用戶在html頁面上調(diào)用插件的時(shí)候,可以自定義鼠標(biāo)移到div上面時(shí)候的文字內(nèi)容了。
$(document).ready(function () {
$('#test').txtHover({ txt: 'test' });
}); 好了,今天的例子到此為止。
相關(guān)文章
JQuery的Ajax請求實(shí)現(xiàn)局部刷新的簡單實(shí)例
本篇文章只要是對JQuery的Ajax請求實(shí)現(xiàn)局部刷新的簡單實(shí)例進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
jQuery控制圖片的hover效果(smartRollover.js)
圖片的hover效果可以用css來實(shí)現(xiàn)也可以用js來實(shí)現(xiàn)。典型的就是smartRollover.js2012-03-03
使用jquery+iframe做一個(gè)ajax上傳效果(實(shí)例)
下面小編就為大家?guī)硪黄褂胘query+iframe做一個(gè)ajax上傳效果(實(shí)例)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
jquery實(shí)現(xiàn)向下滑出的二級導(dǎo)航下滑菜單效果
這篇文章主要介紹了jquery實(shí)現(xiàn)向下滑出的二級導(dǎo)航下滑菜單效果,涉及jquery實(shí)現(xiàn)頁面結(jié)點(diǎn)樣式動(dòng)態(tài)變換效果的實(shí)現(xiàn)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08
jQuery progressbar通過Ajax請求實(shí)現(xiàn)后臺進(jìn)度實(shí)時(shí)功能
這篇文章主要介紹了jQuery progressbar通過Ajax請求實(shí)現(xiàn)后臺進(jìn)度實(shí)時(shí)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
jQuery實(shí)現(xiàn)美觀的多級動(dòng)畫效果菜單代碼
這篇文章主要介紹了jQuery實(shí)現(xiàn)多級動(dòng)畫效果菜單代碼,涉及jquery針對頁面元素的遍歷及事件綁定操作頁面元素樣式變換的技巧,界面美觀實(shí)用,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
jQuery實(shí)現(xiàn)動(dòng)態(tài)添加和刪除input框代碼實(shí)例
這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)添加和刪除input框,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
web開發(fā)人員學(xué)習(xí)jQuery的6大理由及jQuery的優(yōu)勢介紹
jQuery是一個(gè)用來簡化HTML客戶端開發(fā)的JS(JavaScrip)庫,它支持HTML DOM處理,同時(shí)還融合了部分HTML和CSS2013-01-01
jquery中取消和綁定hover事件的實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄猨query中取消和綁定hover事件的實(shí)現(xiàn)代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06

