js實例教程-jquery插件製作教程 txtHover

发布时间:2018-11-23 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了js實例教程-jquery插件製作教程 txtHover脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小寶典致力於為廣大程序猿(媛)提供高品質的代碼服務,請大家多多光顧小站,小寶典在此謝過。

定義插件的結構骨架:
  書中最開始使用的結構骨架如下:

代碼如下:


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" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html XMlns="https://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>
<p id="test">
this is test.</p>
</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);  


第一個版本,當頁面加載完畢之後,p的內容就被修改了,這樣的設計沒多大用處。我們最常用到的是,當鼠標移到到文字上面的時候產生一些變化。改進的插件添加了hover事件。首先我們把p的原始值保存在變量temp裡面,當鼠標移動到p上面的時候,文字被替換,鼠標移出時,將文字替換回來。
添加自定義選項
  為了方便用戶更加靈活的使用,我們需要添加自定義的功能,插件代碼修改:

. 代碼如下:


(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頁面上調用插件的時候,可以自定義鼠標移到p上面時候的文字內容了。
$(document).ready(function () {
  $('#test').txtHover({ txt: 'test' });
});  好了,今天的例子到此為止。

定義插件的結構骨架:
  書中最開始使用的結構骨架如下:

代碼如下:


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" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="https://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>
<p id="test">
this is test.</p>
</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);  


第一個版本,當頁面加載完畢之後,p的內容就被修改了,這樣的設計沒多大用處。我們最常用到的是,當鼠標移到到文字上面的時候產生一些變化。改進的插件添加了hover事件。首先我們把p的原始值保存在變量temp裡面,當鼠標移動到p上面的時候,文字被替換,鼠標移出時,將文字替換回來。
添加自定義選項
  為了方便用戶更加靈活的使用,我們需要添加自定義的功能,插件代碼修改:

. 代碼如下:


(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頁面上調用插件的時候,可以自定義鼠標移到p上面時候的文字內容了。
$(document).ready(function () {
  $('#test').txtHover({ txt: 'test' });
});  好了,今天的例子到此為止。

覺得可用,就經常來吧!Javascript技巧 腳本寶典 歡迎評論哦!&nbsp;js技巧,巧奪天工,精雕玉琢。小寶典獻醜了!

脚本宝典总结

以上是脚本宝典为你收集整理的js實例教程-jquery插件製作教程 txtHover全部内容,希望文章能够帮你解决js實例教程-jquery插件製作教程 txtHover所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。