如何利用 CSS 选中激活标签并影响相邻元素的样式?

如何利用 css 选中激活标签并影响相邻元素的样式?

如何利用 css 选中激活标签并影响相邻元素?

为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作:

对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置:

li:has(+li.active) {
  border-radius: 0 0 10px 0;
}

同样地,对于激活标签相邻前的元素,可以使用以下代码进行设置:

li:has(~:nth-last-child(1).active) {
  border-radius: 0 10px 0 0;
}

需要注意的是,:has 选择器在某些老旧浏览器中兼容性较差。因此,在实际项目中可以使用以下 javascript 代码进行兼容性处理:

document.querySelectorAll('li').forEach((item) => {
  item.addEventListener('click', (e) => {
    if (!e.target.classList.contains('active')) {
      e.target.classList.add('active');
    }

    const prevSibling = e.target.previousElementSibling;
    const nextSibling = e.target.nextElementSibling;

    if (nextSibling && !nextSibling.classList.contains('active')) {
      nextSibling.style.borderRadius = '0 0 10px 0';
    }

    if (nextSibling && nextSibling.classList.contains('active')) {
      nextSibling.style.borderRadius = '0 10px 10px 0';
    }

    if (prevSibling && !prevSibling.classList.contains('active')) {
      prevSibling.style.borderRadius = '0 10px 0 0';
    }

    if (prevSibling && prevSibling.classList.contains('active')) {
      prevSibling.style.borderRadius = '10px 10px 0 0';
    }
  });
});

以上就是如何利用 CSS 选中激活标签并影响相邻元素的样式?的详细内容,更多请关注其它相关文章!