Ich habe Ajax verwendet, um Informationen vom Controller abzurufen und sie als eine Liste von Checkboxen in meiner Ansicht anzuzeigen.Checkbox, die nicht an Controller gebunden ist
$(document).ready(function() {
$('#submitButton').hide(); //hide some buttons
$("#Name").hide();
$("#Contact").hide();
$("#Desc").hide();
$("#PMeeting").hide();
$("#Params").hide();
$('#SelectedTeam').change(function() {
$('#content').html('');
$.ajax({
url: '/Audits/GetAuditParams', //this function retrieves a list of objects
type: "POST",
dataType: "json",
data: {
'tn': $('#SelectedTeam').val(),
},
success: function (data) { //here I create the table with checkboxes and labels
$.each(data, function (i, item) {
var li = $('<input type="checkbox" value="' + item.Included + '" name=Parameters[' + i + '].Included id=Parameters_' + i + '__Included"/>' +
'<label for="Parameters[' + i + ']"></label></br>').
text(item.ParameterDescription).prop('checked', item.Included);
li.find('label').text(item.ParameterDescription);//I create a set of hiddem fields with the same new, otherwise the collection will be null in the controller
$('<input>').attr({
type: 'hidden',
id: 'Parameters_' + i + '__Included',
name: 'Parameters[' + i + '].Included'
}).appendTo('form');
$('#content').append(li);
});
}
});
$.ajax({ //this is for a different information
url: '/Audits/GetAuditInfo',
type: "POST",
dataType: "json",
data: {
'tn': $('#SelectedTeam').val(),
},
success: function (data) {
$("#SProject_ProjectName").val(data.ProjectID);
$("#SProject_POC").val(data.POC);
$("#SProject_PDescription").val(data.PDescription);
$("#SProject_PeriodicMeeting").val(data.PeriodicMeeting);
$("#Name").show();
$("#Contact").show();
$("#Desc").show();
$("#PMeeting").show();
$("#Params").show();
}
});
$('#submitButton').show();
});
function isChecked(value) {
if (value == 1) {
return true;
}
else
return false;
}
$('form').submit(function (e) {
$('input[type=checkbox]').prop('checked', function (index, value) {
if (value == true) {
$('#Parameters_' + index + '__Included').val(1);
$('#Parameters_' + index + '__Included').prop('checked', "checked");
} else {
$('#Parameters_' + index + '__Included').val(0);
}
});
});
});
Das ist mein HTML-Code
<html>
<head>
</head>
<body>
<div class="col-md-4" id="content"></div>
</body>
</html>
Aber ich bin immer die Informationen für die Kontrollkästchen in der Steuerung null, ModelStated.isvalid = false
und das ist der Fehler
Der Wert ‚0 'gilt nicht für enthalten.
und alle Kontrollkästchen (aktiviert oder deaktiviert) haben den Wert "false".