Готовность HTML кода
Привет всем!
Такая задача:
Активация по событию onload не подходит, т.к. это событие наступает только после загрузки остальных элементов (изображений и т.п.). Как вариант я пробовал вставлять активирующий JavaScript-код непосредственно перед закрывающим тегом </body>. Этот вариант срабатывает, но мне очень хотелось-бы "уйти" от этого дополнительного активирующего кода. Желательно, чтобы весь скрипт целиком располагался в <head>...</head>. Решаема такая задача? |
Цитата:
Как минимум два плюса от подключения js в конце файла: 1. Пользователь сразу грузит полезный ему контент, а не ждет, пока загрузится бесполезный в данный момент JavaScript. 2. Не нужны никакие onload. Цитата:
Ну и, разумеется, данное событие есть во всех современных фреймворках. |
Kolyaj,
Спасибо огромное! Это именно то, что я искал. Цитата:
Цитата:
И если юзер работает через прокси, то с определенной долей вероятности, ему почти не придется ждать и при первом заходе. |
Скрипты, подключенные в теле документа, визуально тормозят загрузку страницы, особенно если в верстке использовалось абсолютное позицонирование, для прибивания футера к низу или поднятия бесполезного для поисковиков, но необходимого пользователю контента в вверх. Используйте событие DOMContentLoaded и его эмуляцию для старых браузеров и ИЕ, которая займет не более десяти строк, но даст больший эффект, чем подключение скрипта до </body>, к тому же в некоторых браузерах, вы не сможете работать с document.body, подключив скрипт до до </body>. Сделайте себе универсальный загрузчик DOMContentLoaded.
|
Цитата:
|
Я написал визуально. Время на загрузку будет одно и тоже, но подключенный в теле документа скрипт начинает загружаться сразу же, тормозя закрытие тега <body>, который часто выступает, как relative-блок для абсолютнопозиционированны х элементов, станица начинает дергаться. Иногда такой эффект может даже мешать нормальной навигации по сайту, во время ожидания загрузки станицы, поэтому такого рода оптимизации уделяют большое внимание при разработке веб-интерфейсов.
|
Octane,
какие-то странные у вас аргументы. Цитата:
Цитата:
|
Перед открытием боди станица еще не видна.
|
А перед закрытием все уже видно, и всем можно пользоваться, и ничего не нужно ждать.
|
Octane,
Я кажется понял Вашу мысль. Сегодня попробую проделать пару экспериментов чтобы проверить то, о чем Вы говорите. |
Кстати, по поводу "времени загрузки".
ИМХО, время "диалапной работы в Интернет" уже давно прошло и сейчас ключевым моментом, действительно становится не "время загрузки", а правильное (красивое) отображение (формирование) кода. |
Цитата:
Цитата:
|
Kolyaj,
Я не думаю, что то, что мы здесь обсуждаем будет такой проблемой для GPRS-загрузки. Я же НЕ предлагаю включать в код вложения по несколько сот кил. И второй вопрос - какой процент посетителей на сайте будет заходить через GPRS, чтобы на них сильно ориентироваться? Если большой, то есть смысл сделать две версии сайта "www" (навороченную) и "wap" (облегченную). А если процент потенциальных GPRS-посетителей малый, то не стоит сильно тратить средства на адаптацию под этих посетителей, они и так уже привыкли что у них все тормозит. ;) И потом GPRS уже тоже начинает отходить на задний план. Сейчас уже набирают популярность более скоростные протоколы. |
А что сложного в том, чтобы JavaScript грузить в последний момент, т.к. он может и не понадобиться? Тем более того же JavaScript'а писать меньше.
|
GPRS/EDGE живее всех живых и еще не скоро пропадет, WAP не значит GPRS и то, что пользователи будут заходить на сайт с телефона. Множество пользователей, которые не могут воспользоваться ADSL или каким-то другим видом доступа в Интернет, а также пользователи ноутбуков повседневно используют GPRS/EDGE (если повезет то 3G) для полноценного доступа в интернет, и их становится все больше и больше с появлением недорогих безлимитных тарифов.
|
Цитата:
Кроме того, возможно, для меня актуальными будут проблемы описанные Octane. А разница в размере JavaScript-кода будет практически не ощутимая. Octane, Целиком с Вами согласен. Я и не говорил, что GPRS умер, я сказал что он уже постепенно вытесняется другими протоколами и процесс этот идет весьма активно. Под WAP я подразумевал "облегчённую" версию сайта и это не обязательно для мобильных устройств. |
Часовой пояс GMT +3, время: 11:15. |