>>>

Проектирование, разработка и оптимизация веб-приложений

Плагины jQuery

Реализация одних и тех же функций в различных приложениях побуждает разработчиков заново писать один и тот же код несколько раз лишь незначительно изменяя его под конкретное приложение.

Плагины jQuery позволяют забыть разработчикам о данной проблеме. Разработчик может один раз написать плагин, который позволяет реализовать определенную функцию и затем использовать его в необходимых приложениях написав только одну строчку кода.

В интернете можно найти огромное количество бесплатных jQuery плагинов написанных другими разработчиками и использовать их для создания своих приложений.

Создание плагина

Для того, чтобы создать плагин необходимо добавить к объекту jQuery.fn свойство, имя которого будет является именем плагина:

Синтаксис:

//Определяем код плагина
(function($){
   $.fn.имяПлагина = function() {
      // Код плагина
   };
})(jQuery);
//Вызываем плагин
$(селектор).имяПлагина();

Обратите внимание: обертка (function($){ }) (jQuery) используется здесь для того, чтобы внутри кода плагина можно было использовать знак $ не боясь при этом, что он будет конфликтовать с другими библиотеками JavaScript.

Ключевое слово this в плагинах

При написании плагинов следует обратить внимание на то, что в коде плагина ключевое слово this будет относиться к jQuery объекту, который вызвал этот плагин, а не к DOM объекту как в функциях обратного вызова.

Это значит, что в коде плагина для того, чтобы обратится к jQuery объекту необходимо использовать this, а в коде функций обратного вызова использовать $(this).

Пример

(function($){
  
/* Создаем плагин с именем plugin, который будет находить сумму содержимого всех 
 выбранных абзацев на странице */
   $.fn.plugin=function(){
      var sum=0;
      /* Для того, чтобы сослаться на выбранный элемент в коде плагина мы 
         используем this, но в функции обратного вызова мы уже должны использовать 
         $(this) для этих же целей */
      this.each(function(){
         sum=sum+Number($(this).html());
      });
      // Возвращаем полученную сумму 
      return sum;
   }

})(jQuery)

Поддержка цепочки методов

Плагин в предыдущем примере возвращал целое значение, но часто плагины используются для модификации группы элементов и передачи их следующему методу в цепочке.

Пример цепочки методов:

//Пример цепочки из двух методов css и html
$("p").css("color","red").html("Новое содержимое");

Для того, чтобы Ваш плагин не "разрывал" цепочку методов необходимо, чтобы он возвращал ключевое слово this.

Пример

(function($){
  
   /* Создаем плагин с именем adjust, который будет устанавливать размер текста 
   выбранных элементов равным 1.4em и передавать их дальше по цепочки методов. */
   $.fn.adjust=function(){
   /* Для того, чтобы поддержать цепочку методов нужно вернуть из плагина 
   преобразованную группу выбранных элементов */
      return this.each(function(){
         $(this).css("fontSize","1.4em");
      });
   }

})(jQuery)

Опции плагинов

Многие плагины позволяют пользователям настраивать их поведение с помощью передаваемых им опций.

Пример

(function($){
  
/* Создаем плагин с именем adjust, который будет устанавливать указанный размер и
 цвет выбранным элементам. */
   $.fn.adjust=function(option){
   /* Установим значения опций по умолчанию. Они будут использованы если пользователь 
   при вызове плагина не передаст значений. */
      var setting={size:'1.4em',color:'red'};
      return this.each(function(){
         // Если пользователь передал опции соединить их с опциями по умолчанию 
         if (option){$.extend(setting,option);}
         $(this).css("fontSize",setting.size);
         $(this).css("color",setting.color);
      });
   }

})(jQuery)

Вынесение кода плагина во внешний файл

Заключительным шагом в создании плагинов должно стать вынесение кода плагина в отдельный файл. И написания инструкций, которые должны разъяснить потенциальным пользователям как и зачем можно использовать Ваш плагин.

Пример

<script src="plugin1.js"></script>

$(document).ready(function(){

   $("#but1").click(function(){
      $("#demo p").adjust();
   });
   $("#but2").click(function(){
      $("#demo p").adjust({size:"2em"});
   });
   $("#but3").click(function(){
      $("#demo p").adjust({size:"1.7em",color:"green"});
   });

});

Размер шрифта:
А
А
А
Цвет сайта:
A
A
A
Изображение:
Вкл.
Выкл.
Обычная версия