当前位置:首页 > JavaScript

js实现单选多选

2026-03-15 21:28:43JavaScript

实现单选功能

在HTML中创建单选按钮组,确保同一组的name属性相同。通过JavaScript监听change事件获取选中值。

<input type="radio" name="gender" value="male"> Male
<input type="radio" name="gender" value="female"> Female
document.querySelectorAll('input[name="gender"]').forEach(radio => {
  radio.addEventListener('change', function() {
    if (this.checked) {
      console.log('Selected:', this.value);
    }
  });
});

实现多选功能

使用checkbox类型输入元素,通过JavaScript获取所有被选中的值。

js实现单选多选

<input type="checkbox" name="fruit" value="apple"> Apple
<input type="checkbox" name="fruit" value="banana"> Banana
<input type="checkbox" name="fruit" value="orange"> Orange
document.querySelector('button').addEventListener('click', function() {
  const selected = [];
  document.querySelectorAll('input[name="fruit"]:checked').forEach(checkbox => {
    selected.push(checkbox.value);
  });
  console.log('Selected:', selected);
});

使用事件委托优化性能

为父元素添加单个事件监听器处理所有单选/多选事件,适合动态生成的选项。

js实现单选多选

document.getElementById('radioGroup').addEventListener('change', function(e) {
  if (e.target.type === 'radio') {
    console.log('Radio selected:', e.target.value);
  }
});

表单提交处理

在表单提交时收集所有选择结果,可通过FormDataAPI简化操作。

document.getElementById('myForm').addEventListener('submit', function(e) {
  e.preventDefault();
  const formData = new FormData(this);

  // 获取单选值
  const gender = formData.get('gender');

  // 获取多选值数组
  const fruits = formData.getAll('fruit');

  console.log({gender, fruits});
});

动态生成选项

通过JavaScript动态创建单选/多选按钮并绑定事件。

const options = ['Red', 'Green', 'Blue'];
const container = document.getElementById('colorOptions');

options.forEach(color => {
  const checkbox = document.createElement('input');
  checkbox.type = 'checkbox';
  checkbox.name = 'colors';
  checkbox.value = color.toLowerCase();

  const label = document.createElement('label');
  label.appendChild(checkbox);
  label.appendChild(document.createTextNode(color));

  container.appendChild(label);
});

标签: 多选单选
分享给朋友:

相关文章

vue实现单选按钮

vue实现单选按钮

使用 v-model 绑定单选按钮 在 Vue 中,可以通过 v-model 实现单选按钮的数据绑定。单选按钮组需要共享同一个 v-model 绑定的变量,并通过 value 属性区分选项。 <…

vue 实现单选

vue 实现单选

实现单选功能的方法 在Vue中实现单选功能可以通过多种方式完成,以下是几种常见的方法: 使用v-model绑定单选按钮 通过v-model可以轻松实现单选功能。将v-model绑定到一个变量,单选…

vue如何实现单选

vue如何实现单选

使用原生 HTML 单选按钮 在 Vue 中可以直接使用 HTML 的原生单选按钮,通过 v-model 绑定数据。 <template> <div> <…

vue图片实现多选

vue图片实现多选

Vue 图片多选实现方法 在 Vue 中实现图片多选功能可以通过以下几种方式完成,具体取决于项目需求和复杂度。 使用 v-model 和数组存储选中状态 通过 v-model 绑定一个数组来记录选中…

js 多选 实现

js 多选 实现

实现多选的 JavaScript 方法 使用复选框(Checkbox)实现多选 通过 HTML 的 checkbox 元素配合 JavaScript 实现多选功能。用户可以选择多个选项,提交时获取所有…

vue实现checkbox单选

vue实现checkbox单选

Vue实现Checkbox单选功能 在Vue中实现Checkbox单选功能,可以通过以下几种方法: 方法一:使用v-model绑定单个变量 通过将多个Checkbox绑定到同一个变量,利用v-mo…