В этой статье я покажу, как добавить призыв к действию Pinterest поверх изображения, когда пользователь активно взаимодействует с ним.
Во-первых, давайте посмотрим, почему вы хотели бы это сделать.
Делиться заботой
То, что составляет хороший контент, часто во многом зависит от конкретных потребностей и интересов конечных пользователей. Хороший контент может быть привлекательным, эффективным, простым, функциональным, информативным, вдохновляющим… и так далее.
Мы привыкли добавлять кнопки социальных сетей или ссылки, чтобы делиться страницей (в идеале, с помощью кнопок без жира ). Facebook, Twitter и Google+ часто являются основными необходимыми.
Мы также можем захотеть, чтобы пользователи могли делиться частями нашей страницы. Содержимое страницы часто состоит из чанков, и каждому из этих чанков может быть предоставлена своя предпочтительная функция совместного использования в социальных сетях.
Например, цитата может быть нацелена на ограничение в 140 символов Twitter, а картинка может быть нацелена на Pinterest.
Давайте посмотрим, как вы настраиваете свои изображения для публикации в Pinterest.
Анатомия булавки URL
URL-адрес Pinterest Pin состоит из четырех компонентов:
- часть URL Pinterest:
https://www.pinterest.com/pin/create/button/
- параметр
url
: адрес страницы для ссылки, закодированный в URL - параметр
media
: адрес картинки для обмена, закодированный в URL - параметр
description
: описательный текст, отображаемый на Pinterest, в кодировке URL, не более 500 символов, но 200 символов, кажется, лучший выбор .
Некоторые элементы данных HTML могут быть добавлены, если вы добавите собственный JavaScript data-pin-do
Pinterest, особенно data-pin-do
и data-pin-config
, но в этом случае он не понадобится, так как это метод без жира, в котором мы полагаемся строгое минимальное количество кода.
Трудно закодированный путь
Код, который мы хотим получить, выглядит следующим образом:
<a href="http://www.pinterest.com/pin/create/button/?url=<page url (encoded)>&media=<picture url (encoded)>&description=<HTML-encoded description>" target="_blank" class="pinterest-anchor pinterest-hidden"> <div class="pinterest-logo"> </div> </a> <img src="<picture url>" data-pin="pinIt" alt="<description>">
Каждое пригодное для дробления изображение (помеченное атрибутом data-pin
) имеет префикс с привязкой к странице общего pinIt
Pinterest с правильными атрибутами в ее URL-адресе, а также pinIt
div
для отображения логотипа.
Здесь используются три CSS-класса: pinterest-anchor
, который абсолютно устанавливает позицию логотипа Pinterest в верхнем левом углу изображения; pinterest-hidden
, который устанавливает статус видимости логотипа, и pinterest-logo
, сам логотип, 40 × 40 пикселей, закодированный в base64 в CSS.
.pinterest-anchor { margin-left:10px; margin-top:10px; position:absolute; z-index:42; width:40px; height:40px; } .pinterest-hidden { display:none; } .pinterest-anchor:hover { display:block !important; } .pinterest-logo { background: url("") no-repeat center center; background-size: 40px 40px; height: 100%; width: 100%; }
Анимационная часть — показ и скрытие логотипа при наведении на изображение — обрабатывается в JavaScript с использованием нотации jQuery:
$("img[data-pin='pinIt']").each(function() { $(this).hover(function() { $(this).prev().css("display", "block") }, function() { $(this).prev().css("display", "none") }); });
Автоматизация — твой друг
Но я не хочу раздувать свой контент-код тем конкретным фрагментом HTML, который ставит префикс для разделяемой картинки. Одна только его часть обслуживания будет иметь определенную стоимость, если что-то изменится, такую как URL ресурса Pinterest, параметры и поддержка других социальных сетей.
Поскольку JavaScript уже используется для управления взаимодействием с мышью, давайте сделаем еще один шаг и сгенерируем этот код для любого изображения на странице.
Используя jQuery снова, мы получаем:
$("img[data-pin='pinIt']").each(function() { $(this).before('<a href="http://www.pinterest.com/pin/create/button/?url=' + encodeURIComponent($(location).attr("href")) + '&media=' + encodeURIComponent($(this).attr("src")) + '&description=' + encodeURIComponent($(this).attr("alt")) + '" target="_blank" class="pinterest-anchor pinterest-hidden"><div class="pinterest-logo"> </div></a>'); $(this).hover(function() { $(this).prev().css("display", "block") }, function() { $(this).prev().css("display", "none") }); });
Для каждого изображения с атрибутом data-pin
установленным на pinIt
, мы pinIt
в pinIt
префикса к pinIt
привязки, получая URL-адрес страницы непосредственно из атрибута location
страницы, URL-адрес изображения из href
изображения и описание из его alt
текста, при этом должным образом кодирование компонентов URI.
Это продемонстрировано в следующем CodePen
Но нужен ли нам jQuery?
Дело в том, что jQuery может и не понадобиться . Если вам это не нужно, вам подойдет простой старый ванильный JavaScript. На самом деле, я считаю хорошим упражнением время от времени переводить фрагменты кода jQuery в обычный JavaScript. Это напоминание о том, как все работает за кулисами.
var pinables = document.querySelectorAll('img'); Array.prototype.forEach.call(pinables, function(el, i){ data = el.dataset; if (data.pin=='pinIt') { el.insertAdjacentHTML('beforebegin', '<a href="http://www.pinterest.com/pin/create/button/?url=' + encodeURIComponent(window.location.href) + '&media=' + encodeURIComponent(el.src) + '&description=' + encodeURIComponent(el.alt) + '" target="_blank" class="pinterest-anchor pinterest-hidden"><div class="pinterest-logo"> </div></a>'); el.onmouseover = function(){ this.previousSibling.style.display='block'; } el.onmouseout = function(){ this.previousSibling.style.display='none'; } } });
Селектор изображений — $("img[data-pin='pinIt']").each
— теперь представляет собой массив всех изображений, для которых мы проверяем значение атрибута данных. Остальная часть кода является прямым переводом реализации jQuery.
Как вы можете видеть в этой ручке, она работает точно так же.
Куда пойти оттуда?
В веб-дизайне и пользовательском опыте простота — путь. Мы не хотим загромождать наши интерфейсы логотипами социальных сетей. В этом смысле этот подход очень чистый: логотип появляется только тогда, когда пользователь наводит курсор на изображение; и логотип Pinterest достаточно известен, поэтому нам не нужно добавлять текстовую ссылку рядом с ним, чтобы объяснить его значение.
Однако форма совместного доступа открывается в новом окне, которое выводит пользователя за пределы текущей страницы. Как утверждает Крэйг Баклер в своей статье , «это слишком далеко для самого нетерпеливого менеджера по социальным медиа». Небольшое всплывающее окно, чтобы показать, что это может быть жизнеспособной альтернативой, для которой он дает ванильную реализацию JavaScript.
Для интересующихся небольшая подсказка: в нашем случае у цели нет атрибута href
, но у его родительского узла он есть. (Вы можете проверить реальную реализацию этого.)
Итак, что вы думаете о кнопках социальных сетей? Вы предпочитаете подход без жира или предпочитаете использовать все функции, которые может предложить JavaScript? Дайте нам знать об этом в комментариях!