Cette fois, je vais vous apporter une explication détaillée des étapes de packaging du plug-in jQuery. Quelles sont les précautions pour le packaging du plug-in jQuery. Voici un cas pratique, jetons un oeil.
L'extension des plug-ins et des méthodes jQuery est très puissante et peut faire gagner beaucoup de temps de développement. Cet article décrit les bases, les meilleures pratiques et les pièges courants du développement de plugins jQuery.
1. Mise en route
L'écriture d'un plug-in jQuery commence par l'ajout de nouveaux attributs fonctionnels à jQuery.fn. are Le nom est le nom de votre plug-in :
Le code est le suivant :
jQuery.fn.myPlugin = function(){ //你自己的插件代码 };
Où sont les symboles que les utilisateurs aiment beaucoup ? Il existe toujours, cependant, afin d'éviter les conflits avec d'autres bibliothèques JavaScript, nous ferions mieux de passer jQuery à un programme fermé auto-exécutable, où jQuery est mappé comme un symbole, afin d'éviter le $ signe utilisé par une autre bibliothèque par écrasement.
. Le code est le suivant :
(function ($) { $.fn.myPlugin = function () { //你自己的插件代码 }; })(jQuery);
Dans ce programme fermé, on peut utiliser le symbole $ sans restriction pour représenter les fonctions jQuery.
2. Environnement
Maintenant, nous pouvons commencer à écrire le code du plug-in. Cependant, avant cela, il faut avoir une idée de l’environnement dans lequel se trouve le plug-in. Dans le cadre du plug-in, le mot-clé this représente l'objet jQuery que le plug-in exécutera. Un malentendu courant est facile à survenir ici, car dans d'autres fonctions jQuery qui contiennent des rappels, le mot-clé this représente l'élément DOM natif. . Cela amène souvent les développeurs à envelopper par erreur le mot-clé this dans jQuery inutilement, comme indiqué ci-dessous.
. Le code est le suivant :
(function ($) { $.fn.myPlugin = function () { //此处没有必要将this包在$号中如$(this),因为this已经是一个jQuery对象。 //$(this)等同于 $($('#element')); this.fadeIn('normal', function () { //此处callback函数中this关键字代表一个DOM元素 }); }; })(jQuery); $('#element').myPlugin();
3. Connaissances de base
Maintenant, nous comprenons les bases. du plug-in jQuery Knowledge, écrivons un plugin qui fait quelque chose.
. Le code est le suivant :
(function ($) { $.fn.maxHeight = function () { var max = 0; this.each(function () { max = Math.max(max, $(this).height()); }); return max; }; })(jQuery); var tallest = $('p').maxHeight(); //返回高度最大的p元素的高度
Il s'agit d'un simple plug-in qui utilise .height() pour renvoyer la hauteur de l'élément p ayant la plus grande hauteur sur la page. .
4. Maintenir la chaînabilité
Souvent, l'intention d'un plug-in est simplement de modifier les éléments collectés d'une manière ou d'une autre et de les transmettre. passez-les à la méthode suivante de la chaîne. C'est la beauté du design de jQuery et l'une des raisons pour lesquelles jQuery est si populaire. Par conséquent, pour maintenir la chaînabilité d'un plugin, vous devez vous assurer que votre plugin renvoie le mot-clé this.
. Le code est le suivant :
(function ($) { $.fn.lockDimensions = function (type) { return this.each(function () { var $this = $(this); if (!type || type == 'width') { $this.width($this.width()); } if (!type || type == 'height') { $this.height($this.height()); } }); }; })(jQuery); $('p').lockDimensions('width').CSS('color', 'red');
Puisque le plugin renvoie ce mot-clé, il maintient la chaînabilité afin que les éléments collectés par jQuery puissent continuer à être contrôlés par les méthodes jQuery telles que .css. . Par conséquent, si votre plugin ne renvoie pas de valeur intrinsèque, vous devez toujours renvoyer le mot-clé this dans sa portée. De plus, vous pouvez en déduire que les paramètres transmis à un plugin seront transmis dans la portée du plugin. Par conséquent, dans l'exemple précédent, la chaîne 'width' devient un paramètre de type du plugin.
5. Valeurs et options par défaut
Pour les plug-ins plus complexes offrant de nombreuses options personnalisables, il est préférable d'avoir un Paramètres par défaut qui peuvent être étendus lorsque le plugin est appelé (en utilisant $.extend). Ainsi, au lieu d'appeler un plugin avec un tas de paramètres, vous pouvez l'appeler avec un paramètre d'objet contenant les paramètres que vous souhaitez remplacer.
. Le code est le suivant :
(function ($) { $.fn.tooltip = function (options) { //创建一些默认值,拓展任何被提供的选项 var settings = $.extend({ 'location': 'top', 'background-color': 'blue' }, options); return this.each(function () { // Tooltip插件代码 }); }; })(jQuery); $('p').tooltip({ 'location': 'left' });
Dans cet exemple, lors de l'appel du plug-in d'info-bulle, l'option d'emplacement dans les paramètres par défaut est écrasée et l'option background-color reste à sa valeur par défaut, il est donc finalement appelé. La valeur du paramètre est :
Le code est le suivant :
{ 'location': 'left', 'background-color': 'blue' }
C'est une manière très flexible de fournir une prise hautement configurable. -in sans que les développeurs aient besoin de définir toutes les options disponibles.
Nommer correctement votre plug-in est une partie très importante du développement de plug-ins. Avec le bon espace de noms, vous pouvez garantir que votre plugin aura très peu de chances d'être écrasé par d'autres plugins ou par un autre code sur la même page. Les espaces de noms vous facilitent également la vie en tant que développeur de plugins, car ils vous aident à mieux suivre vos méthodes, vos événements et vos données.
7. Méthode du plug-in
在任何情况下,一个单独的插件不应该在jQuery.fnjQuery.fn对象里有多个命名空间。
. 代码如下:
(function ($) { $.fn.tooltip = function (options) { // this }; $.fn.tooltipShow = function () { // is }; $.fn.tooltipHide = function () { // bad }; $.fn.tooltipUpdate = function (content) { // !!! }; })(jQuery);
这是不被鼓励的,因为它.fn使.fn命名空间混乱。 为了解决这个问题,你应该收集对象文本中的所有插件的方法,通过传递该方法的字符串名称给插件以调用它们。
. 代码如下:
(function ($) { var methods = { init: function (options) { // this }, show: function () { // is }, hide: function () { // good }, update: function (content) { // !!! } }; $.fn.tooltip = function (method) { // 方法调用 if (methods[method]) { return methods[method].apply(this, Array.prototype.slice.call(arguments, 1)); } else if (typeof method === 'object' || !method) { return methods.init.apply(this, arguments); } else { $.error('Method' + method + 'does not exist on jQuery.tooltip'); } }; })(jQuery); //调用init方法 $('p').tooltip(); //调用init方法 $('p').tooltip({ foo: 'bar' }); // 调用hide方法 $(‘p').tooltip(‘hide'); //调用Update方法 $(‘p').tooltip(‘update', ‘This is the new tooltip content!');
这种类型的插件架构允许您封装所有的方法在父包中,通过传递该方法的字符串名称和额外的此方法需要的参数来调用它们。 这种方法的封装和架构类型是jQuery插件社区的标准,它被无数的插件在使用,包括jQueryUI中的插件和widgets。
八、事件
一个鲜为人知bind方法的功能即允许绑定事件命名空间。 如果你的插件绑定一个事件,一个很好的做法是赋予此事件命名空间。 通过这种方式,当你在解除绑定的时候不会干扰其他可能已经绑定的同一类型事件。 你可以通过追加命名空间到你需要绑定的的事件通过 ‘.'。
. 代码如下:
(function ($) { var methods = { init: function (options) { return this.each(function () { $(window).bind('resize.tooltip', methods.reposition); }); }, destroy: function () { return this.each(function () { $(window).unbind('.tooltip'); }) }, reposition: function () { //... }, show: function () { //... }, hide: function () { //... }, update: function (content) { //... } }; $.fn.tooltip = function (method) { if (methods[method]) { return methods[method].apply(this, Array.prototype.slice.call(arguments, 1)); } else if (typeof method === 'object' || !method) { return methods.init.apply(this, arguments); } else { $.error('Method ' + method + ' does not exist on jQuery.tooltip'); } }; })(jQuery); $('#fun').tooltip(); //一段时间之后… … $(‘#fun').tooltip(‘destroy');
在这个例子中,当tooltip通过init方法初始化时,它将reposition方法绑定到resize事件并给reposition非那方法赋予命名空间通过追加.tooltip。 稍后, 当开发人员需要销毁tooltip的时候,我们可以同时解除其中reposition方法和resize事件的绑定,通过传递reposition的命名空间给插件。 这使我们能够安全地解除事件的绑定并不会影响到此插件之外的绑定。
九、数据
通常在插件开发的时候,你可能需要记录或者检查你的插件是否已经被初始化给了一个元素。 使用jQuery的data方法是一个很好的基于元素的记录变量的途径。尽管如此,相对于记录大量的不同名字的分离的data, 使用一个单独的对象保存所有变量,并通过一个单独的命名空间读取这个对象不失为一个更好的方法。
. 代码如下:
(function ($) { var methods = { init: function (options) { return this.each(function () { var $this = $(this), data = $this.data('tooltip'), tooltip = $('<p />', { text: $this.attr('title') }); // If the plugin hasn't been initialized yet if (!data) { /* Do more setup stuff here */ $(this).data('tooltip', { target: $this, tooltip: tooltip }); } }); }, destroy: function () { return this.each(function () { var $this = $(this), data = $this.data('tooltip'); // Namespacing FTW $(window).unbind('.tooltip'); data.tooltip.remove(); $this.removeData('tooltip'); }) }, reposition: function () { // ... }, show: function () { // ... }, hide: function () { // ... }, update: function (content) { // ... } }; $.fn.tooltip = function (method) { if (methods[method]) { return methods[method].apply(this, Array.prototype.slice.call(arguments, 1)); } else if (typeof method === 'object' || !method) { return methods.init.apply(this, arguments); } else { $.error('Method ' + method + ' does not exist on jQuery.tooltip'); } }; })(jQuery);
将数据通过命名空间封装在一个对象中,可以更容易的从一个集中的位置读取所有插件的属性。
十、总结和最佳做法
编写jQuery插件允许你做出库,将最有用的功能集成到可重用的代码,可以节省开发者的时间,使开发更高效。 开发jQuery插件时,要牢记:
1.始终包裹在一个封闭的插件:
. 代码如下:
(function($) { /* plugin goes here */ })(jQuery);
2.不要冗余包裹this关键字在插件的功能范围内
3.除非插件返回特定值,否则总是返回this关键字来维持chainability 。
4.传递一个可拓展的默认对象参数而不是大量的参数给插件。
5.不要在一个插件中多次命名不同方法。
3.始终命名空间的方法,事件和数据。
最后加一个自己写的放大镜的插件`
(function($){$.fn.Fdj=function(){ $('#smallImg').on('mouseover', function() { $('#slider').show(); }) $('#smallImg').on('mouseout', function() { $('#slider').hide(); }) $('#smallImg').on('mousemove', function(e) { var x = e.clientX - $('#slider').width() / 2; var y = e.clientY - $('#slider').height() / 2; if(x <= 0) { x = 0 } if(x > $('#smallImg').width() - $('#slider').width()) { x = $('#smallImg').width() - $('#slider').width(); } if(y <= 0) { y = 0 } if(y > $('#smallImg').height() - $('#slider').height()) { y = $('#smallImg').height() - $('#slider').height(); } $('#slider').css({ 'left': x, 'top': y }) var X=x/$('#smallImg').width()*800 var Y=y/$('#smallImg').height()*800 $('#img').css({ left:-X, top:-Y }) }) } })(jQuery)
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!