gpt4 book ai didi

html - 仅使用 CSS 在按钮列表中单击按钮显示

转载 作者:太空宇宙 更新时间:2023-11-04 10:55:17 26 4
gpt4 key购买 nike

我在 HTML 中有 4 个按钮,它们采用列表 (ul > li) 格式。我想实现一种功能,其中一个按钮将显示为已单击(已应用已单击的 css 样式)。然后单击列表中的任何其他按钮时,已经单击的按钮样式应该更改,然后只有新单击的按钮应显示为已单击(应用单击的 css 样式)。因此,其他按钮将具有未单击的样式。

这可以使用 javascipt 来处理,但我特别希望仅使用 css 来实现。我无法解决这个问题。

我是 CSS 编程的新手,因此请求这方面的帮助。

最佳答案

在从所有其他元素中删除该类后,将一个类添加到被单击的元素。使用 jquery addClassremoveClass 方法。使用带有输入标签的 css 可以实现的唯一扩展是使用伪类 :focus(任何点击按钮外虽然会移除焦点。)。如果您要单击按钮以外的任何地方,则无法保留样式。

$(document).ready(function(){
$('input[type=button]').click(function(){
$('.active').removeClass('active');
$(this).addClass('active');
});
});
.active{
background:white;
border:1px solid red;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<ul> <li> <input type="button" value="A"/> </li> <li> <input type="button" value="B"/> </li> <li> <input type="button" value="C"/> </li> <li> <input type="button" value="D"/> </li> </ul>

如果您想避免使用 jquery,则使用 selector.className(字符串类型)或 selector.classList(数组类型)。

编辑

如果您愿意使用 anchor 而不是输入标签,那么我为您提供了一个纯 css 解决方案。

a {
display: block;
border: 2px solid black;
text-align: center;
margin:5px;
text-decoration:none;
}



a:active,a:target {
border: 2px solid red;
}
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<meta charset="utf-8">
<title>JS Bin</title>
</head>
<body>

<ul> <li> <a href="#a" id="a"/>a</a> </li> <li> <a href="#b" id="b"/>b</a> </li> <li> <a href="#c" id="c"/>c</a> </li> <li> <a href="#d" id="d"/>d</a> </li> </ul>
</body>
</html>

关于html - 仅使用 CSS 在按钮列表中单击按钮显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34674473/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com