#javascript #html #jquery #css
Вопрос:
Я создал пользовательское поле выбора и хотел получить значение выбранной метки, когда я нажимаю кнопку «проверить», я получаю предупреждение, в котором отображается код внутри div, что кажется логичным, вопрос в том, как я могу получить значение или текст выбранной опции.
.selectbox_newpost {
padding:0;
margin:0;
height:100vh;
width:100vw;
font-family: sans-serif;
color:#FFF;
}
.selectbox_newpost {
display:flex;
flex-direction: column;
position:relative;
width:250px;
height:40px;
}
.option_newpost {
padding:0 30px 0 10px;
min-height:40px;
display:flex;
align-items:center;
background:#333;
border-top:#222 solid 1px;
position:absolute;
top:0;
width: 100%;
pointer-events:none;
order:2;
z-index:1;
transition:background .4s ease-in-out;
box-sizing:border-box;
overflow:hidden;
white-space:nowrap;
}
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<link rel="stylesheet" href="stylesss.css">
<script src="https://code.jquery.com/jquery-3.6.0.js" integrity="sha256-H K7U5CnXl1h5ywQfKtSj8PCmoN9aaq30gDh27Xc0jk=" crossorigin="anonymous"></script>
<meta charset="utf-8">
<title>test</title>
</head>
<body>
<script type="text/javascript">
function clicked(){
var option = document.getElementById("selectedOptionNewpost");
alert(option.innerHTML);
}
</script>
<div class="selectbox_container_newpost">
<div id="selectedOptionNewpost" class="selectbox_newpost" tabindex="1">
<input class="selectopt" name="test" type="radio" id="opt1" checked>
<label for="opt1" class="option_newpost">Objects</label>
<input class="selectopt" name="test" type="radio" id="opt2">
<label for="opt2" class="option_newpost">Vehicules</label>
<input class="selectopt" name="test" type="radio" id="opt3">
<label for="opt3" class="option_newpost">Technology</label>
<input class="selectopt" name="test" type="radio" id="opt4">
<label for="opt4" class="option_newpost">Books</label>
<input class="selectopt" name="test" type="radio" id="opt5">
<label for="opt5" class="option_newpost">Furniture</label>
<input class="selectopt" name="test" type="radio" id="opt6">
<label for="opt6" class="option_newpost">Others...</label>
</div>
</div>
<button onclick="clicked()">Check</button>
</body>
</html>
Комментарии:
1. Для этого вы могли бы использовать
select
. Тогда вам будет намного проще найти выбранный вариант.2. Как я могу это сделать?
3. @decpk есть много причин не использовать этот
<select>
механизм. Обычно считается, что он крайне недружелюбен к пользователям.4. @Pointy Что это значит? Просто любопытно…
5. @decpk таким программистам, как мы, легко пользоваться, но для нормальных людей это странно и неочевидно. Были проведены исследования удобства использования, которые продемонстрировали это.
Ответ №1:
Вы можете найти выбранный переключатель, а затем связанную с ним метку и распечатать текстовый контент.
Проверьте ниже
Пожалуйста, дайте мне знать, если это то, что вы искали.
.selectbox_newpost {
padding:0;
margin:0;
height:100vh;
width:100vw;
font-family: sans-serif;
color:#FFF;
}
.selectbox_newpost {
display:flex;
flex-direction: column;
position:relative;
width:250px;
height:40px;
}
.option_newpost {
padding:0 30px 0 10px;
min-height:40px;
display:flex;
align-items:center;
background:#333;
border-top:#222 solid 1px;
position:absolute;
top:0;
width: 100%;
pointer-events:none;
order:2;
z-index:1;
transition:background .4s ease-in-out;
box-sizing:border-box;
overflow:hidden;
white-space:nowrap;
}
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<link rel="stylesheet" href="stylesss.css">
<script src="https://code.jquery.com/jquery-3.6.0.js" integrity="sha256-H K7U5CnXl1h5ywQfKtSj8PCmoN9aaq30gDh27Xc0jk=" crossorigin="anonymous"></script>
<meta charset="utf-8">
<title>test</title>
</head>
<body>
<script type="text/javascript">
function clicked(){
var option = document.getElementById("selectedOptionNewpost");
const radioSelected = option.querySelector("input[type='radio']:checked")
const labelForSelectedRadio = option.querySelector(`label[for=${radioSelected.getAttribute('id')}]`)
console.log(labelForSelectedRadio.textContent)
}
</script>
<div class="selectbox_container_newpost">
<div id="selectedOptionNewpost" class="selectbox_newpost" tabindex="1">
<input class="selectopt" name="test" type="radio" id="opt1" checked>
<label for="opt1" class="option_newpost">Objects</label>
<input class="selectopt" name="test" type="radio" id="opt2">
<label for="opt2" class="option_newpost">Vehicules</label>
<input class="selectopt" name="test" type="radio" id="opt3">
<label for="opt3" class="option_newpost">Technology</label>
<input class="selectopt" name="test" type="radio" id="opt4">
<label for="opt4" class="option_newpost">Books</label>
<input class="selectopt" name="test" type="radio" id="opt5">
<label for="opt5" class="option_newpost">Furniture</label>
<input class="selectopt" name="test" type="radio" id="opt6">
<label for="opt6" class="option_newpost">Others...</label>
</div>
</div>
<button onclick="clicked()">Check</button>
</body>
</html>
Ответ №2:
или если вы используете jQuery:
function clicked(){
alert($("input[type=radio][name=test]:checked").attr('id'));
alert($("input[type=radio][name=test]:checked").attr('value'));
}
Но вы должны добавить атрибут значения в радиобуттон:
<input class="selectopt" name="test" type="radio" id="opt4" value="4">