Ссылки в HTML

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

Такая часть HTML как «Гипертекст» определяет, какой вид ссылок мы используем: гипертекстовые ссылки (или гиперссылки).

В HTML ссылки — это строчные элементы, написанные с помощью тега <a>.

Атрибут href (hypertext reference) используется для определения цели ссылки (куда вы переходите при щелчке по ней).

<p>
  Чтобы найти что-либо, посетите <a href="http://www.google.com">Google</a>.
</p>

Ссылки являются основным взаимодействием с веб-страницей: вы переходите от одного документа к другому, щёлкая по ссылкам.

Есть три вида цели, которые вы можете определить:

  • ссылки с якорем для навигации в пределах одной страницы;
  • относительные адреса, как правило, для навигации в пределах одного сайта;
  • абсолютные адреса, как правило, для перехода на другой сайт.

Ссылки с якорем

Ссылки с якорем предназначены для навигации в пределах одной страницы. Предваряя значение атрибута href с #, вы можете настроить переход к элементу HTML с определённым атрибутом id.

Например, <a href="#footer"> будет переходить к <div id="footer"> в том же HTML-документе. Такой тип href часто используется, чтобы вернуться обратно к верхней части страницы.

Относительные адреса

Если вы хотите определить ссылку на другую страницу того же сайта, вы можете использовать относительные адреса.

Но по отношению к чему? Ну, относительно текущей страницы.

Давайте используем простой пример, в котором папка my-first-website содержит два файла HTML.

В home.html вы хотите определить ссылку на contact.html. Поскольку эти два файла находятся в одной папке, вы можете просто написать в home.html:

<p>
  Перейти на <a href="contact.html">страницу контактов</a>.
</p>

На реальном сайте процесс аналогичен.

Скажем, у вас есть сайт с именем http://ireallylovecats.com, на котором у вас есть две веб-страницы: index.html и gallery.html:

В index.html вы могли бы написать следующую ссылку:

<p>
  Посетите <a href="gallery.html">галерею</a>!
</p>

Помните: веб-сайты размещаются на компьютерах, таких же, что вы сейчас используете. Они просто называются «серверы», потому что их единственная цель состоит в том, чтобы хранить сайты. Но у них ещё есть файлы и папки, как на «обычных» компьютерах.

Абсолютные адреса

Если вы хотите поделиться с другом своей галереей кошек, то не можете просто отправить gallery.html, так как этот относительный адрес работает только для HTML-документов, которые находятся на том же компьютере или домене.

Вам нужен полный адрес вашего HTML-документа: http://ireallylovecats.com/gallery.html.

Этот URL может быть разбит на три части:

  • протокол http://
  • домен ireallylovecats.com
  • путь к файлу gallery.html

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

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

В файле http://ireallylovecats.com/gallery.html, вы могли бы написать:

<p>
  Найти другие изображения кошек в моём <a href="https://twitter.com/ireallylovecats">Твиттере</a>!
</p>

Относительные или абсолютные ссылки?

Допустим, вы хотите связать первую страницу со второй. Наиболее прямой подход заключается в использовании абсолютного адреса. Таким образом, вы добавляете <a href="http://ireallylovecats.com/gallery.html">Перейти на вторую страницу</a> в файл index.html.

Поскольку эти два файла находятся в той же папке, вы можете использовать относительный адрес с помощью <a href="first-blog-post.html">. Это полезно, если вы решите переместить папку: ваши ссылки не будут нарушены, так как цели ссылок относительны друг к другу, до тех пор, как вы перемещаете оба файла одновременно и держите их в одной папке. Этот относительный подход особенно полезен при переключении доменов.

Перейти к заданиям

Автор и редакторы

Автор: Джереми Томас
Последнее изменение: 25.03.2016
Редакторы: Влад Мержевич