【Labs】CSSでリンクやClickイベントを無効にする
こんにちは(・∀・)
レスポンシブデザインでWebページをスマホサイトとPCサイトに振り分けたとき、ある要素のスマホサイトにはリンクがあり、PCサイトではなしにするという仕様のとき、PCサイトのリンククリックを無効にする方法はないのか…と調べてみたらありました。CSSだけで簡単にできるようです。
サンプル
CSSでリンクやClickイベントを無効にする
a {
pointer-events: none;
}
a要素に直接指定すると無効になりません。a要素の親要素に指定してください。
親要素にpointer-events:noneを指定してリンクを無効にしても、a要素自身にpointer-events:autoを指定するとリンクは有効になります。
CSS
.link a {
color: #d49fc2;
pointer-events: none;
}
@media (min-width: 768px) {
.link a {
color: #4776AF;
pointer-events: auto;
}
.link a:hover {
color: #afc6e2;
}
/* ** */}
Result
関連リンク
【Guide】スマホサイトの作成・レスポンシブデザイン
【Guide】スマホサイトの作成・基本編
参考
CSSでJavaScriptのClickイベントやリンククリック時の動作などを禁止する方法
要素のクリック動作を無効にするCSS