jQuery - это JavaScript библиотека, призванная облегчить и без того нелегкую жизнь веб-разработчика. Благодаря ей мы можем манипулировать DOM-элементами, обрабатывать события, выполнять AJAX-запросы и многое другое с помощью изящного API. И сегодня я хочу дать несколько полезных советов о том, как писать правильный (оптимизированный) jQuery код.
Кэшируйте DOM-элементы
Кэширование DOM-элементов позволяет избежать лишней траты ресурсов если вы собираетесь использовать их в коде несколько раз:
// плохо h = $('#element').height(); $('#element').css('height',h-20); // ништяк $element = $('#element'); h = $element.height(); $element.css('height',h-20);
Также можно закэшировать родительский элемент для дальнейшего обращения к его дочерним элементам:
// плохо var $container = $('#container'), $containerLi = $('#container li'), $containerLiSpan = $('#container li span'); // ништяк (быстрей) var $container = $('#container '), $containerLi = $container.find('li'), $containerLiSpan= $containerLi.find('span');
Избегайте глобальных переменных
Убедитесь, что вы ограничиваете область видимости ваших переменных. Это хорошая практика:
// плохо $element = $('#element'); h = $element.height(); $element.css('height',h-20); // ништяк var $element = $('#element'); var h = $element.height(); $element.css('height',h-20);
Используйте Венгерскую нотацию
Размещение $ перед именами переменных поможет вам легко отличать те, которые содержат jQuery-объекты.
// плохо var ololo = $('#ololo'); var value = $ololo.val(); // ништяк var $ololo = $('#ololo'); var value = $ololo.val();
Используйте "var" цепочки
Вместо того, что бы использовать "var" каждый раз при объявлении переменной, воспользуйтесь следующей конструкцией:
var $first = $('#first'), $second = $('#second'), value = $first.val(), k = 3, cookiestring = 'SOMECOOKIESPLEASE', i, j, myArray = {};
Переменные, которым вы не присваиваете значение сразу, лучше размещать в конце.
Отдавайте предпочтение ".on()"
Начиная с версии 1.7 в jQuery появился метод .on() для создания обработчика того или иного события. Предпочтительней использовать именного его:
// не очень хорошо $first.click(function(){ $first.css('border','1px solid red'); $first.css('color','blue'); }); $first.hover(function(){ $first.css('border','1px solid red'); }) // так то лучше $first.on('click',function(){ $first.css('border','1px solid red'); $first.css('color','blue'); }) $first.on('hover',function(){ $first.css('border','1px solid red'); })
Сокращайте jQuery-код
По возможности сокращайте ваш jQuery-код:
// плохо $first.click(function(){ $first.css('border','1px solid red'); $first.css('color','blue'); }); // ништяк $first.on('click',function(){ $first.css({ 'border':'1px solid red', 'color':'blue' }); });
Используйте цепочки методов
jQuery дает нам возможность объединять несколько методов в цепочку. Не упусти эту возможность, бро!
// плохо $second.html(value); $second.on('click',function(){ alert('hello everybody'); }); $second.fadeIn('slow'); $second.animate({height:'120px'},500); // ништяк $second.html(value); $second.on('click',function(){ alert('hello everybody'); }).fadeIn('slow').animate({height:'120px'},500);
Сохраняйте код читабельным
Если слишком увлекаться предыдущим советом, код может стать неудобным для восприятия. Используйте табуляцию и переносы строк что бы сохранить читабельность:
// плохо $second.html(value); $second.on('click',function(){ alert('hello everybody'); }).fadeIn('slow').animate({height:'120px'},500); // ништяк $second.html(value); $second .on('click',function(){ alert('hello everybody');}) .fadeIn('slow') .animate({height:'120px'},500);
Сокращайте ваш код
Сокращайте код по возможности:
// плохо function initVar($myVar) { if(!$myVar) { $myVar = $('#selector'); } } // ништяк function initVar($myVar) { $myVar = $myVar || $('#selector'); }
// плохо if(collection.length > 0){..} // ништяк if(collection.length){..}
Отделяйте (detach) элементы если собираетесь выполнить ресурсоемкие операции над ними
Если вы собрались выполнить ресурсоемкие операции над некоторым элементом, будет лучше сперва отделить его а потом прикрутить назад:
// плохо var $container = $("#container"), $containerLi = $("#container li"), $element = null; $element = $containerLi.first(); //... a lot of complicated things // ништяк var $container = $("#container"), $containerLi = $container.find("li"), $element = null; $element = $containerLi.first().detach(); //...те самые трудоемкие операции $container.append($element);
Знайте нюансы
Прежде чем воспользоваться тем или иным jQuery-методом убедитесь, что нет его более быстрого или предпочтительного эквивалента:
// плохо $('#id').data(key,value); // ништяк (быстрей) $.data('#id',key,value);
Избегайте универсальных селекторов
Вперемешку с другими селекторами универсальный селектор * довольно медленный:
// плохо $('.container > *'); // ништяк $('.container').children();
Даже если вы опускаете селектор, универсальный селектор * всеравно применяется:
// плохо $('.someclass :radio'); // ништяк $('.someclass input:radio');
Оптимизируйте селекторы
Например, обращение к элементу по его id не требует каких-либо дополнительных селекторов:
// плохо $('div#myid'); $('div#footer a.myLink'); // ништяк $('#myid'); $('#footer .myLink');
Не используйте несколько селекторов id:
// плохо $('#outer #inner'); // ништяк $('#inner');
Не используйте запрещенные методы
Старайтесь не использовать запрещенные методы.
Исходный материал Writing Better jQuery Code.