如何验证多个单选按钮。所有这些单选按钮都是动态生成的。
<input type="radio" name="answer_option1" value="1" id="ans_options1" />
<input type="radio" name="answer_option1" value="2" id="ans_options2" />
<input type="radio" name="answer_option1" value="3" id="ans_options3" />
<input type="radio" name="answer_option1" value="4" id="ans_options4" />
<input type="radio" name="answer_option2" value="5" id="ans_options5" />
<input type="radio" name="answer_option2" value="6" id="ans_options6" />
<input type="radio" name="answer_option2" value="7" id="ans_options7" />
<input type="radio" name="answer_option2" value="8" id="ans_options8" />
<input type="radio" name="answer_option3" value="9" id="ans_options9" />
<input type="radio" name="answer_option3" value="10" id="ans_options10" />
<input type="radio" name="answer_option3" value="11" id="ans_options11" />
<input type="radio" name="answer_option3" value="12" id="ans_options12" />
<input type="radio" name="answer_option4" value="13" id="ans_options13" />
<input type="radio" name="answer_option4" value="14" id="ans_options14" />
<input type="radio" name="answer_option4" value="15" id="ans_options15" />
<input type="radio" name="answer_option4" value="16" id="ans_options16" />
答案 0 :(得分:10)
试试这个http://jsfiddle.net/aamir/r9qR2/
由于每个组都有不同的名称属性,因此您必须对每组单选按钮进行验证。
if($('input[name="answer_option1"]:checked').length === 0) {
alert('Please select one option');
}
如果您拥有无限数量的群组。试试这个http://jsfiddle.net/aamir/r9qR2/2/
//Make groups
var names = []
$('input:radio').each(function () {
var rname = $(this).attr('name');
if ($.inArray(rname, names) == -1) names.push(rname);
});
//do validation for each group
$.each(names, function (i, name) {
if ($('input[name="' + name + '"]:checked').length == 0) {
console.log('Please check ' + name);
}
});
如果您只想为所有群组显示1个错误。试试这个http://jsfiddle.net/aamir/r9qR2/4/
答案 1 :(得分:1)
尝试这个新的小提琴http://jsfiddle.net/Hgpa9/3/
$(document).on("click","#validate", function() {
var names = [];
$('input[type="radio"]').each(function() {
// Creates an array with the names of all the different checkbox group.
names[$(this).attr('name')] = true;
});
// Goes through all the names and make sure there's at least one checked.
for (name in names) {
var radio_buttons = $("input[name='" + name + "']");
if (radio_buttons.filter(':checked').length == 0) {
alert('none checked in ' + name);
}
else {
// If you need to use the result you can do so without
// another (costly) jQuery selector call:
var val = radio_buttons.val();
}
}
});
答案 2 :(得分:0)
public async Task<DepartmentModel> GetDepartmentProfile(int deptId)
{
//Operation to get all department and employee details, based on department ID
List<EmployeesModel> employees = new List<EmployeesModel>();
DepartmentModel dept = new DepartmentModel();
List<DepartmentEscalateModel> escContacts = new List<DepartmentEscalateModel>();
DataSet ds = new DataSet();
Parameters @params = new Parameters();
EmployeeService empService = new EmployeeService();
//code to populate model pieces
//call out to service to return a list of models to bind to the DepartmentModel
var empInfo = await empService.GetEmployeeDetails(dr2["accountname"].ToString());
return dept;
}
GetEmployeeDetails() declaration
public async Task<List<EmployeesModel>> GetEmployeeDetails(string account)
{
//return employee details, works when called from other areas
}