CSS: стиль внешних ссылок - PullRequest
       30

CSS: стиль внешних ссылок

31 голосов
/ 21 марта 2011

Я хочу стилизовать все внешние ссылки на моем сайте (Wordpress).Я пытаюсь с:

.post p a[href^="http://"]:after

Но Wordpress поместил весь URL в ссылки ... Итак, как я могу стилизовать все ссылки, которые не начинаются с http://www.mywebsite.com?

Спасибо.

Ответы [ 6 ]

47 голосов
/ 21 марта 2011

Используя специальный синтаксис CSS, вы можете легко это сделать. Вот один из способов работы протоколов HTTP и HTTPS:

a[href^="http://"]:not([href*="example.com"]):after,
a[href^="https://"]:not([href*="example.com"]):after{
    content: " (EXTERNAL)" 
}

Вы можете просмотреть пример этого, нажав здесь .

10 голосов
/ 21 июня 2012

Так показываются внешние ссылки ALA Wikipedia:

a[href^="http"]:after {
     content: " " url();
}

Пример можно найти здесь: http://jsfiddle.net/ZkbKp/

4 голосов
/ 12 марта 2014

Я объединил @superlogical + @Shaz, чтобы сделать что-то для моей темы Foundation WP ...

a[href^="http://"]:not([href*="maggew.com"]):after {
     content: " " url();    
}

Вы можете использовать этот HTML-фрагмент для тестирования на своем сайте:

<a href="http://gebfire.com" target="_blank">External</a>

This is a working example, look above to change the color to monochrome



Это то, что я использовал для пользовательского изображения (например, значок)

a[href^="http://"]:not([href*="magew.com"]):after {
     content: " " url('/wp-content/uploads/2014/03/favicon.png');    
}

This is a working example, look for the favicon - see it?

3 голосов
/ 13 апреля 2017

Одно простое правило, не требующее жесткого кодирования:

a[href*="//"] { /* make me do stuff */ }

Работает для всех схем. Имеет дополнительное преимущество определения внутренних опечаток. Для скрытых внутренних ссылок, перенаправляемых извне, просто добавьте относительный URL к префиксу //.

Благодарность принадлежит Марку Баттистелле, который оставил этот фрагмент на CSS-Tricks в 2012 году.

Обновление: На основании фактического использования Я лично нашел вышеупомянутое проблематичным, так как он стилизует все абсолютные ссылки, которые могут привести к неожиданному стилеванию в некоторых ситуациях (например, в Brave, когда Вы загружаете страницу для просмотра в автономном режиме). Я предлагаю использовать a[rel*="external"]::after вместо этого и украсить ваши внешние ссылки.

0 голосов
/ 13 февраля 2019

Псевдоэлементы имеют в синтаксисе '::' вместо ':'.

Существует также необходимость сопоставления URL-адреса, начинающегося с «http», а не «http://'» или «https://'.

».

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

Чтобы добавить аккуратный значок, вы можете поместить SVG в переменную CSS, а затем использовать его в своем правиле CSS.

    --icon-external-link: url('data:image/svg+xml,\
        <svg xmlns="http://www.w3.org/2000/svg" viewBox="-24 -24 48 48"> \
            <defs> \
                <mask id="corner"> \
                    <rect fill="white" x="-24" y="-24" width="48" height="48"></rect> \
                    <rect fill="black" x="2" y="-24" width="22" height="26"></rect> \
                </mask> \
            </defs> \
            <g stroke="blue" fill="blue" stroke-width="4"> \
                <rect x="-20" y="-16" width="32" height="32" rx="7" ry="7" stroke-width="3" fill="none" mask="url(%23corner)"/> \
                <g transform="translate(1,0)" stroke-linecap="square"> \
                    <line x1="0" y1="0" x2="17" y2="-17" stroke-width="6"/> \
                    <polygon points="21 -21, 21 -8, 8 -21" stroke-linejoin="round" stroke-width="3"/> \
                 </g> \
             </g> \
        </svg>');

Это выглядит странно, но это аккуратный значок внешней ссылки, который можно редактировать в соответствии с вашей темой, не возвращаясь к настольному издательскому приложению. Поскольку значок является частью таблицы стилей, вам не нужно, чтобы браузер делал для него дополнительную загрузку. Кроме того, потому что это SVG является четким. «Прямоугольник» - это поле, группа с «линией» и «многоугольником» - это стрелка. Все числа являются целыми числами, и вы можете изменить их, если хотите.

Тогда в вашем правиле вы можете сослаться на это так:

a[href^="http"]:not([href*="example.mil"])::after {
    content: '';
    background: no-repeat left .25em center var(--icon-external-link);
    padding-right: 1.5em;
}

Соответствующие ссылки начинаются с http и не включают ваше доменное имя. И 'http://', и' https://' начинаются с 'http', поэтому нет необходимости дублировать правило в соответствии с принятым ответом.

Если вы используете в своем контенте ссылки без протокола, начинающиеся с '//', то это необходимо учитывать.

Возможно, вы также захотите строго соблюдать порядок открытия внешних ссылок. Например, вы можете всегда открывать внешние ссылки на новой вкладке с целевым пустым подходом. Чтобы сделать это правильно, вам нужно включить в свои ссылки target="_blank", а также rel="noopener noreferrer". Поэтому, чтобы определить, где этого нет в вашей разметке, вы можете настроить таргетинг только на ссылки, которые имеют правильные атрибуты rel.

0 голосов
/ 19 апреля 2018

Предположим, вы устанавливаете цель для внешних ссылок с помощью <a href='http://' target='_blank'>Justin Bieber Fan Club</a> , Вы можете сделать игру:

CSS:

a[target="_blank"]:after{
     content: " [external]" 
}
...