All-For-Kompa.RU

Сегодня:
Карта сайта форум Главная
Скрыть рекламный блок

Всё для компа

chat

Видео дня

Популярное

Реклама

Хочешь помочь проекту? Установи наш баннер!

Партнёры



Развлекательный портал по игре Dota 2. У нас вы первым узнаете о последних игровых новостях, сможете почитать интересные статьи и гайды, посмотреть стримы популярных комментаторов и многое другое.

Про-софт - сайт професионального софта. Ето сайт не только софта но также игровых дополнений, музыки, фильмов, игр для ПК а также читов для ПК игр. Постоянное обновление материалов и каждый день появляется чтото новенькое!

Авторизация


Реклама

Хочешь помочь проекту? Установи наш баннер!

Опрос

что лучше?

1. Mozilla Firefox
2. Opera
3. IE

Реклама

Хочешь помочь проекту? Установи наш баннер!

Популярные тэги

Комментарии

Счетчики

На сайте: 1
Прохожие: 1
Пользователей: 0
Статус:

Счётчик тИЦ и PR Rambler's Top100
HTML и DHTML [2] JavaScript [5]
Mootools [2] JQuery [22]
Разное [2] CSS [4]
PHP [1]
АвторАвтор: leonP4 | ДатаДата: 05.01.2011 |Голосов: 0


Как Вы знаете — в разработке объёмного JS-приложения где используется популярнейшая библиотека jQuery наступает момент когда остро встаёт проблема производительности. Все силы кидаются на амбразуру профайлера, каждый вызов скрупулёзно исследован, каждый функционально нагруженный кусок реализации обнюхан со всех сторон и выправлен. Но беда поступает не с той стороны, откуда её ждут 90% разработчиков. Селекторы — Как много в этом слове.
Давайте разберёмся — как работает эта магия и почему поиск DOM-элементов может стать причиной падения производительности приложения.

Как jQuery разбирает селектор


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

querySelectorAll()

В новых браузерах появилась отменная функция querySelectorAll() и querySelector(), которая умеет производить поиск элементов используя возможности браузера (в частности — используемые при просмотре CSS и назначении свойств элементам). Работает данная функция не во всех браузерах, а только в FF 3.1+, IE8+ (только в стандартном режиме IE8), Opera 9.5+(?) и Safari 3.1+. Так вот Sizzle всегда определяет наличие данной функции и пытается любой поиск выполнить через неё. Однако, тут не без сюрпризов — для успешного использования querySelectorAll() наш селектор должен быть валидным.
Приведу простой пример:
Два приведенных селектора практически ничем не отличаются и вернут одинаковый набор элементов. Однако первый селектор вернёт результат работы querySelectorAll(), а второй — результат обычной фильтрации по элементам.
$('#my_form input[type="hidden"]')
$('#my_form input[type=hidden]')

Разбор селектора и поиск

Если не удалось использовать querySelectorAll(), Sizzle будет пытаться использовать обычные функции браузера getElementById(), getElementsByName(), getElementsByTagName() и getElementByClass(). В большинстве случаев их хватает, но (sic!) в IE < 9 getElementByClassName() поломана и использование селектора по классу приведёт к полному перебору элементов в этом браузере.
В общем случае Sizzle разбирает селектор справа налево. Для иллюстрации данной особенности приведу несколько примеров:
$('.divs .my_class')
Сначала будут найдены элементы .my_class, а потом отфильтрованы только те, которые имеют .divs в родителях. Как мы видим — это довольно затратная операция, причём использование контекста не решает проблемы (о контексте мы поговорим ниже).
Как я уже сказал — в большинстве случаев Sizzle будет разбирать селектор справа налево, но не в случае использования элемента с ID:
$('#divs .my_class')
В таком случае селектор поведёт себя как ожидалось и сразу будет взят элемент #divs для использования в виде контекста.

Контекст

Второй параметр, передаваемый вместе с селектором в функцию $() называется контекстом. Он призван сузить круг поиска элементов. Однако — при разборе контекст пристыкуется к началу селектора, что выигрыша совершенно не даёт. Выигрышная комбинация использования контекста — валидный селектор для querySelectorAll(), так как данная функция может быть применена не только от имени document, но и от элемента. Тогда селектор с контекстом образно трансформируется следующую конструкцию:
$('.divs', document.getElementById('wrapper'));
document.getElementById('wrapper').querySelectorAll('.divs'); // при наличии возможности использовать querySelectorAll()

В данном примере, если невозможно использовать querySelectorAll(), Sizzle будет фильтровать элементы простым перебором.
Ещё одно замечание о контексте (речь не о селекторах) — если вторым параметром в селектор для функции .live() передать объект jQuery — событие будет ловиться на document(!), а если DOM-объект — то всплывать событие будет только до этого элемента. Такие тонкости я стараюсь не запоминать, а использую .delegate().

Фильтры и иерархия элементов

Для поиска вложенных элементов можно воспользоваться следующим селектором:
$('.root > .child')
Как мы знаем — разбор селектора и поиск начнётся со всех .child элементов на странице (при условии, что querySelectorAll() недоступно). Такая операция достаточно затратна и мы можем трансформировать селектор так:
$('.child', $('.root')[0]); // использование контекста не облегчит поиск
$('.root').find('.child'); // а зачем нам перебор всех элементов внутри .root?
$('.root').children('.child'); // самый правильный вариант

Однако, если есть необходимость использовать фильтры по каким-либо атрибутам (:visible, :eq и т.д.) и селектор выглядит так:
$('.some_images:visible')
то фильтр будет применён в последнюю очередь — т.е. мы опять отступаем от правила «справа налево».

Итоги

  • По возможности используйте правильные селекторы, подходящие под querySelectorAll()
  • Заменяйте подчинённости внутри селекторов на подзапросы (.children(...) и т.д.)
  • Уточняйте контекст селектора
  • Фильтруйте как можно меньший готовый набор элементов

Быстрых селекторов Вам в новом году! Всех в наступившим!

По мотивам мастер-класса Ильи Кантора

Уважаемый посетитель, Вы зашли на сайт как незарегистрированный пользователь. Мы рекомендуем Вам зарегистрироваться либо войти на сайт под своим именем.
Всего комментариев: 0
Добавлять комментарии могут только зарегистрированные пользователи.
[ Регистрация | Вход ]

Популярные файлыНовые файлы
Call of Duty 5: World at ...[ Скачали 67387 раз ]
Амфибии, Гайд по ассасина...[ Скачали 31766 раз ]
Амфибии, Гайд по шаманам.[ Скачали 30675 раз ]
cs 1.6 patch v48 full[ Скачали 29056 раз ]
Русский бот PW Alfa v 2.6[ Скачали 17200 раз ]
Огромный пак глюков и баг...[ Скачали 12756 раз ]
civilization 5 скачать бе...[ Скачали 11947 раз ]
PW MP5[ Скачали 11162 раз ]
MHS-Bot-PW 2.3 ботовод[ Скачали 10413 раз ]
Niko Bellic (нико белич) ...[ Скачали 10014 раз ]
Wallpapers Girls №1051[ Добавлен 26.04.2024 ]
Wallpapers Mix №1138[ Добавлен 25.04.2024 ]
Jawbreaker (2024/Ru/En/Mu...[ Добавлен 25.04.2024 ]
Wallpapers Girls №1050[ Добавлен 25.04.2024 ]
Eclipse: Echo of Dimensio...[ Добавлен 25.04.2024 ]
Phantom Fury (2024/Ru/En/...[ Добавлен 25.04.2024 ]
Sweet Transit (2024/Ru/En...[ Добавлен 24.04.2024 ]
Teenage Mutant Ninja Turt...[ Добавлен 24.04.2024 ]
Wallpapers Mix №1137[ Добавлен 24.04.2024 ]
Wallpapers Girls №1049[ Добавлен 22.04.2024 ]