日常开发中我们经常会在客户端向服务器端传递参数,下面以asp.net core为例 专门分享传递对象或对象数组方法
一、键值对专递对象
以下是一个表单,现在需求是将以下 表单 所有input元素以独享数组方式传递到服务器端(以下是服务端代码,for循环并未执行,执行后会生成若干对象 )。
1.准备表单
<form method="post" id="frm3"> <table id="q"> <tr> <td> 教材名称 </td><td> 题型 </td><td> 试题数量 </td><td> 易 </td><td> 中 </td><td> 难</td> </tr> @{ int j = 0;} @foreach (RndEntity item in _qs.getRndPaperParams(ViewBag.bookIDS)) { <tr> <td> @item.bookName <input type="hidden" name="bookName" value="@item.bookName" /> </td> <td> @qt.Where(t => t.Key.Equals(item.qst_type)).First().Value <input type="hidden" name="qst_type" value="@item.qst_type" /> </td> <td> @item.total <input type="hidden" name="total" value="@item.total" /> </td> <td> 易:<input type="number" ID="y_@j@item.qst_type" name="Y" onkeyup="this.value=this.value.replace(/[^\d]/g,'') " value="0" required max="@item.Y" min="0" /> </td> <td> 中:<input type="number" ID="z_@j@item.qst_type" name="Z" onkeyup="this.value=this.value.replace(/[^\d]/g,'') " value="0" required max="@item.Z" min="0" /> </td> <td> 难:<input type="number" ID="n_@j@item.qst_type" name="N" onkeyup="this.value=this.value.replace(/[^\d]/g,'') " value="0" required max="@item.N" min="0" /> </td> </tr> j++; } </table> <a href="#" class="easyui-linkbutton" id="hello">content</a> </form>
要向服务器端传递对象数组 ,直接传递 服务器端 不会接收到对象列表。
2.利用js封装对象数组
<script type="text/javascript"> $(function () { $("#hello").click(function () { var question = {} //新建 question对象 var rndConfigArr = [];//新建对象容器 用户存储 question $("#q tr ").each(function (index, item) { //遍历 表格每行 元素 // console.log( item) if (index > 0) {
//新建对象装入数组 rndConfigArr.push({ bookName: $(item).find("input:eq(0)").val(), qst_type: $(item).find("input:eq(1)").val(), total: parseInt($(item).find("input:eq(2)").val()), Y: parseInt($(item).find("input:eq(3)").val()), Z: parseInt($(item).find("input:eq(4)").val()), N: parseInt($(item).find("input:eq(5)").val()) }) } }) // {List:rndConfigArr} $.ajax({ url: '/paper/t', type: 'post', data: { List: rndConfigArr }, // 键值对 传送到服务器端 此处不用 JSON。stringfy( )是因为要专递多个对象 success: function (res) { console.log(res); } }); }); })
function serializeForm(form) {
var obj = {};
$.each(form.serializeArray(), function () {
if (obj[this["name"]]) {
obj[this["name"]] = obj[this["name"]] + "," + this['value'];
}
else {
obj[this["name"]] = this['value'];
}
});
return obj;
}
</script>
3.服务器端接收
[HttpPost] public IActionResult t(List<RndEntity> List) { return Json(List); }
标签:asp,服务器端,对象,tcore,item,input,eq,find,服务端 From: https://www.cnblogs.com/sunzzhankui/p/16829992.html