Если вы хотите, чтобы это был только CSS, логика отключения должна определяться CSS.
Чтобы переместить логику в определениях CSS, вам придется использовать селекторы атрибутов. Вот несколько примеров:
Отключить ссылку с точным href: =
Вы можете отключить ссылки, содержащие определенное значение href, например:
<a href="//website.com/exact/path">Exact path</a>
[href="//website.com/exact/path"]{
pointer-events: none;
}
Отключить ссылку, содержащую фрагмент пути: *=
Здесь любая ссылка, содержащая /keyword/
в пути, будет отключена
<a href="//website.com/keyword/in/path">Contains in path</a>
[href*="/keyword/"]{
pointer-events: none;
}
Отключить ссылку, начинающуюся с: ^=
оператор [attribute^=value]
предназначается для атрибута, который начинается с определенного значения. Позволяет отказаться от веб-сайтов и корневых путей.
<a href="//website.com/begins/with/path">Begins with path</a>
[href^="//website.com/begins/with"]{
pointer-events: none;
}
Вы даже можете использовать его для отключения не-https ссылок. Например:
a:not([href^="https://"]){
pointer-events: none;
}
Отключить ссылку, заканчивающуюся на: $=
Оператор [attribute$=value]
предназначается для атрибута, который заканчивается определенным значением. Может быть полезно отказаться от расширений файлов.
<a href="/path/to/file.pdf">Link to pdf</a>
[href$=".pdf"]{
pointer-events: none;
}
или любой другой атрибут
Css может предназначаться для любого атрибута HTML. Может быть rel
, target
, data-custom
и т. Д. *
<a href="#" target="_blank">Blank link</a>
[target=_blank]{
pointer-events: none;
}
Объединение селекторов атрибутов
Вы можете связать несколько правил. Допустим, вы хотите отключить все внешние ссылки, но не те, которые указывают на ваш сайт:
a[href*="//"]:not([href*="my-website.com"]) {
pointer-events: none;
}
Или отключить ссылки на pdf-файлы определенного сайта:
<a href="//website.com/path/to/file.jpg">Link to image</a>
[href^="//website.com"][href$=".jpg"] {
color: red;
}
Поддержка браузера
Селекторы атрибутов поддерживаются начиная с IE7. :not()
селектор начиная с IE9.