如何使用jQuery单击单选按钮时将值推送到隐藏的输入类型?

问题描述 投票:0回答:3

我从数组格式的一个变量获取值,因此通过使用for循环它将迭代,当单击输入类型单选按钮时,每个值用逗号分隔推送到隐藏字段

我尝试了这个但没有插入任何内容。如何将这些值推送到隐藏字段?

var id = ["1", "2"]; // getting this value from another varaible in array format

for (var i = 0; i < id.length; i++) {
  $("input[name=radion_btn" + id[i] + "]").change(function() {
    $(".selected_val").push(id[i]); //values like 1,2 want to push in hidden field when click on radio button
  });
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="hidden" name="selected_val[]" value="" class="selected_val" />
<input type="radio" name="radion_btn1" value="" />
<input type="radio" name="radion_btn2" value="" />
javascript jquery
3个回答
1
投票

根据你的代码。当你的事件发生时,for(var i = 0; i < id.length; i++) {会跑两次。那时我的值是2,id [2]未定义。下面的代码应该工作。

var id = ["1", "2"]; // getting this value from another varaible in array format
arrayData = [];
for (var i = 0; i < id.length; i++) {
  $("input[name=radion_btn" + id[i] + "]").change(function() {
    console.log($(this).val());
    arrayData.push($(this).val()); //values like 1,2 want to push in hidden field when click on radio button
    $('.selected_val').val(arrayData.join());
  });
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="value" name="selected_val[]" value="" class="selected_val" />
<input type="radio" name="radion_btn1" value="1" />
<input type="radio" name="radion_btn2" value="2" />

0
投票

您可以通过在新值之前添加隐藏输入值来模拟推送

var id = ["1", "2"]; // getting this value from another varaible in array format

for (var i = 0; i < id.length; i++) {
  $(".selected_val").val("");
  $("input[name=radion_btn" + id[i] + "]").change(function() {
    $(".selected_val").val((i == 0 ? "" : ",") + $(".selected_val").val() + id[i]);
  });
}

0
投票

以下是一种可能有用的方法示例。请参阅下面的代码段中的评论。

let obj = {};  // create an empty object to store the clicked values
$(".radio").change(function() {  // when a radio button is clicked
  obj[this.id] = $(this).val();  // store it in the object
  $(".selected_val").val(JSON.stringify(obj));  // and add the object to hidden field as string
  console.log($(".selected_val").val());  // spit it out to the console
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="hidden" name="selected_val[]" value="" class="selected_val" />
<input type="radio" class="radio" name="radion_btn1" id="1" value="1" />1
<input type="radio" class="radio" name="radion_btn2" id="2" value="2" />2
<input type="radio" class="radio" name="radion_btn3" id="3" value="3" />3

您会注意到我为所有单选按钮添加了一个公共类。这就是我将事件处理程序附加到的内容。我还将ID添加到单选按钮元素中。

这可能会或可能不会最适合您的方案,但希望能让您开始朝着正确的方向前进。

更新

如果您希望将值存储在数组中,只需将其更改为数组:

let arr = [];
$(".radio").change(function() {
    arr.push($(this).val());
    $(".selected_val").val(JSON.stringify(arr));
}

当然,这不会将ID与对象的值相关联。

© www.soinside.com 2019 - 2024. All rights reserved.