Как я могу получить значение выбранной опции с помощью Javascript или Jquery?

#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">