AJAX - новый модный термин, знание которого причисляет человека к сонму людей, идущих не то чтобы в ногу со временем, а даже слегка впереди. Что скрывается за этими буквами?
Аббревиатура расшифровывается как Asynchronous JavaScript + XML (асинхронный JavaScript+XML). Википедия дает следующее определение: Ajax - это подход к построению интерактивных пользовательских интерфейсов веб-приложений. При использовании Ajax веб-страница не перезагружается полностью в ответ на каждое действие пользователя. Вместо этого с веб-сервера догружаются только нужные пользователю данные.
Т.о. основным отличием Ajax-технологии является возможность частичной загрузки страницы, что позволяет увеличить скорость и повысить юзабилити.
Асинхронный обмен данными, который осуществляют AJAX-технологии, более приемлем с точки зрения юзабилити, потому что пользователю не придется смотреть в пустой экран, дожидаясь перезагрузки страницы. Содержимое страницы, однажды загрузившись, уже не исчезнет с дисплея. В идеале, пользователь вообще не должен замечать, когда приложение обратилось к серверу, потому что данные подгружаются в фоновом режиме мелкими порциями.
Ajax на весь сайт?
Идея использовать Ajax на всем сайте давно волнует многих. В этом случае при клике на любую ссылку, обновлялась бы только нужная часть страницы. С точки зрения функциональности это плюс. Однако есть и несколько минусов.
Во-первых, использование только Javascript-навигации просто губительно для SEO, поэтому лучше стараться избегать этого.
Во-вторых, при использовании Ajax-технологий на всем сайте приведет к невозможности использовать закладок и кнопки «назад».
Закладки и кнопка «назад»
Одним из свойств обычных веб-страниц на HTML является то, что пользователи могут передавать ссылки другим людям, чтобы они могли увидеть то же самое. Также можно создать закладку страницы и возвратиться к ней позже. JavaScript, а. следовательно. технология AJAX в этом случае препятствуют этому. Так как страница динамически генерируется JavaScript, а не передается сервером, при этом у нее остается один физический адрес, то в результате для получения необходимой информации тому пользователю, которому вы отослали ссылку, придется еще раз также догружать страницу, как это делали вы.
Кнопка возвращения назад является прекрасным дополнением к пользовательскому интерфейсу. К сожалению, кнопка “назад” в большинстве случаев не совместима с JavaScript. Потеря этой функциональной возможности является одной из главных причин того, чтобы не создавать веб-приложения, которые полностью реализуются на JavaScript.
Прокручивание (Scrolling)
Еще одной проблемой является эффект, который влияет на прокрутку страницы. Пользователь может читать статью или прокручивать длинный список, дойдя до определенного момента пользователь решает вернуться обратно. Для этого ему приходится вновь догружать ту информацию, которую уже прочитал. Согласитесь, что это выбивает из колеи..
AJAX и SEO
Если Вы хотите, чтобы сайт корректно индексировался поисковыми системами, для этого нужно как можно реже использовать javascript, особенно это касается навигационного меню. Роботы поисковых систем пока не научились индексировать ссылки, выполненные с помощью Java-script. поэтому старайтесь использовать приемы стандартного HTML при создании ссылок.
В том случае, если вы не желаете избавляться от java-ссылок, поскольку они выполняют на вашем сайте определенную роль, к примеру, создают некоторый визуальный эффект, притягивающий внимание человека, то самым простым способом не обидеть себя и роботов поисковых систем в этом случае является способ, при котором вы должны продублировать java-ссылки обычными.
Следует отметить, что javat-ссылки выглядят также как и обычные:
Обычная ссылка: http://www.ragepank.com/spam-o-meter/
Javascript-ссылка: http://www.ragepank.com/#spam-o-meter/
Это огромный плюс с точки зрения юзабилити.
Javascript в контенте
Многие подтвердят, что элементы на Javascript в тексте, встроенные в страницы, не совсем удобны для работы. Однако их все-таки используют, например, для маскировки email-адресов, что помогает сократить количество почтового спама.
Кроме того, многие функции, реализованные с помощью рассматриваемой технологии AJAX, затрудняют работу DOM-парсера. (Document Object Model - платформенно-независимый программный интерфейс, позволяющий программам и скриптам управлять содержимым документов HTML и XML, а также изменять их структуру и оформление)
Небольшое заключение
Функциональные качества Ajax-технологий могут увеличить скорость сайта, упростить навигацию, и вероятно, помочь в вопросах безопасности, поскольку с помощью Java-script мы можем скрывть и кодировать информацию.