我有一个html表单,并且其中也有复选框。复选框的值通过Web Api来自SQL数据库。
$(document).ready(function () {
var $MaterialName = $('#materiallist');
function addMaterials(material) {
$MaterialName.append('<input type="checkbox" >' + material.MaterialName + ' </input>');
}
<div class="form-group">
<label for="material" class="col-xs-3 control-label header">Käytetyt materiaalit</label>
<div class="col-xs-7">
<div class="checkbox" id="materiallist"></div>
</div>
</div>
我想将这些检查值以及该表单中的其他输入值保存到另一个SQL数据库(名为Form)中。
我还没有找到还需要保存所有其他输入字段的解决方案,只有解决方案只有复选框和按钮。另外,我的值来自数据库,而不是“硬编码”选项。
我尝试过:
function getCheckedMaterials() {
var materialArray = [];
$("#materiallist input:checked").each(function () {
materialArray.push($(this).val());
});
var selected;
selected = materialArray.join(',');
alert("You have selected " + selected);
}
这无法满足我的需要,因为我无法获取这些值。
当我按下#tallenna
按钮时,来自其他输入字段的所有这些值都将进入Form数据库。我需要将选中的值另存为MaterialName
作为文本。
$('#tallenna').click(function () {
var form = {
FormFiller: $FormFiller.val(),
CustomerContact: $CustomerContact.val(),
ReadyToDate: $ReadyToDate.val(),
Instructions: $Instructions.val(),
Amount: $Amount.val(),
PcsAmount: $PcsAmount.val(),
ChargeFull: $ChargeFull.val(),
ChargeByPcs: $ChargeByPcs.val(),
FreightCost: $FreightCost.val(),
CustomerName: $CustomerName.val(),
WorkName: $WorkName.val(),
MaterialName: getCheckedMaterials // ????
};
答案 0 :(得分:1)
您似乎在询问如何将数据从函数返回到属性。这样,在函数中添加return
语句,然后通过在函数名称末尾添加()
从属性中调用它,如下所示:
function getCheckedMaterials() {
var materialArray = $("#materiallist input:checked").map(function () {
return this.value;
}).get();
return materialArray.join(',');
}
$('#tallenna').click(function (e) {
e.preventDefault();
var form = {
// other properties...
MaterialName: getCheckedMaterials()
};
// send 'form' in an AJAX request here...
});
我建议从函数返回纯materialArray
数组,并将其在AJAX请求中发送到WebAPI端点。这样,您可以将其模型绑定到string[]
或IEnumerable<string>
上,从而更易于使用。