ASP.NET MVC - Ajax 将空值传递给控制器
ASP.NET MVC - Ajax passing null value to controller
我正在尝试使用 Ajax 将数据从视图发送到控制器,但是数据正在发送到控制器,因为 null.I 尝试了很多东西但找不到 solution.frombody
属性'解决不了这个问题,我在启动时做了一些更改,但它们也没有帮助我。
这是我的脚本:
$(document).ready(function() {
$("#addColumn").click(function() {
AddColumnRecords();
});
$("#saveRecords").click(function() {
SaveRecords();
});
});
function AddColumnRecords() {
var columnRecords="<tr><td>" + $("#columnName").val() + "</td><td>" + $("#type").val() +"</td><td>"+ document.getElementById('primaryCheck').checked+ "</td></tr>";
$("#ColumnTable").last().append(columnRecords);
$("#columnName").val(" ");
}
function SaveRecords() {
var Columns = new Array();
$("#ColumnTable").find("tr:gt(0)").each(function(){
var name=$(this).find("td:eq(0)").text();
var type=$(this).find("td:eq(1)").text();
var isPrimary=$(this).find("td:eq(2)").text();
var ColumnModel={};
ColumnModel.Name = name;
ColumnModel.Type = parseInt(type);
ColumnModel.IsPrimaryKey = isPrimary;
Columns.push(ColumnModel);
});
var Table={};
var tableName=$("#tableName").val();
Table.TableName=tableName;
Table.Columns=Columns;
console.log(JSON.stringify(Table));
$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data:{table : JSON.stringify(Table)},
success:function(data){alert("success")},
error:function(){alert("error")}
});
}
我的table是:
public class Table
{
public string TableName { get; set; }
public List<Column> Columns { get; set; } = new List<Column>();
}
列模型 class 是:
public class Column
{
public string Name { get; set; }
public virtual Types Type { get; set; } = Types.String;
public virtual bool IsPrimaryKey { get; set; } = false;
}
这是操作方法:
[HttpPost]
public IActionResult CreateTable([FromBody] Table table)
{
return View();
}
console log
<div class="mb-3">
<label for="tableName" class="form-label">Table Name</label>
<input type="text" class="form-control" id="tableName" aria-describedby="tableName">
</div>
<form>
<div class="mb-3">
<label for="columnName" class="form-label">Name</label>
<input type="text" class="form-control" id="columnName" aria-describedby="columnName">
</div>
<div class="mb-3">
<select class="form-select" aria-label="Default select example" id="type">
@{
<option value=3>@DatabaseSample.Models.Types.String</option>
<option value=0>@DatabaseSample.Models.Types.Integer</option>
<option value=5>@DatabaseSample.Models.Types.Boolean</option>
<option value=4>@DatabaseSample.Models.Types.Char</option>
<option value=2>@DatabaseSample.Models.Types.Double</option>
<option value=1>@DatabaseSample.Models.Types.Float</option>
<option value=6>@DatabaseSample.Models.Types.Date</option>
}
</select>
</div>
<div class="mb-3 form-check">
<input type="checkbox" class="form-check-input" id="primaryCheck">
<label class="form-check-label" for="exampleCheck1">Primary key</label>
</div>
</form>
<button id="addColumn" type="submit" class="btn btn-primary">Submit</button>
<table class="table" id="ColumnTable">
<thead>
<tr>
<th scope="col">Column name</th>
<th scope="col">Type</th>
<th scope="col">Primary key</th>
</tr>
</thead>
</table>
<button id="saveRecords" type="submit" class="btn btn-primary">Save</button>
删除 [FromBody] 并试试这个
let Table = {
TableName: $("#tableName").val(),
ColumnsStr :JSON.stringify(Columns)
//create a new property in Table model, calls ColumnsStr which will receive ColumnsStr
};
$.ajax({
type:'POST',
dataType:'json',
contentType:'application/json; charset=utf-8',
url:'@(Url.Action("CreateTable", "table"))',
data:Table,
success:function(data){alert("success")},
error:function(){alert("error")}
});
在控制器中你可以这样做:
table.Columns = JsonSerializer.Deserialize<List<Column>>(table.ColumnsStr)
在您的 ajax 发送代码中,您将模型转换为字符串!
$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data:{table : JSON.stringify(Table)}, // <<------------- HERE
success:function(data){alert("success")},
error:function(){alert("error")}
});
这意味着你发送这样的模型; { table: "..."}
但是您的控制器需要 Table 模型。
解决方案的第一个选项;不要通过 JSON.stringfy()
转换为字符串
$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data: Table, // <<------------- HERE
success:function(data){alert("success")},
error:function(){alert("error")}
});
或者第二个选项;将控制器参数从 Table 更改为字符串。当你得到模型字符串时,然后在控制器函数中将其转换为 Table 模型。
[HttpPost]
public IActionResult CreateTable([FromBody] string table)
{
var mTable = new JavaScriptSerializer().Deserialize<Table>(table);
return View();
}
仅用于发送 table 使用此
data: JSON.stringify(Table)
下面是工作demo,大家可以参考一下
更改 ajax 如下所示:
...
var Table={};
var tableName=$("#tableName").val();
Table.TableName=tableName;
Table.Columns=Columns;
console.log(JSON.stringify(Table));
$.ajax({
url:'/Home/Createtable',
type:'POST',
data:Table,
success:function(data){alert("success")},
error:function(){alert("error")}
});
在家庭控制器中:
public IActionResult Index()
{
return View();
}
[HttpPost]
public JsonResult CreateTable(Table table, List<Column> Columns)
{
var ccc = 0; // do your staff...
return Json(ccc);
}
结果:
我正在尝试使用 Ajax 将数据从视图发送到控制器,但是数据正在发送到控制器,因为 null.I 尝试了很多东西但找不到 solution.frombody
属性'解决不了这个问题,我在启动时做了一些更改,但它们也没有帮助我。
这是我的脚本:
$(document).ready(function() {
$("#addColumn").click(function() {
AddColumnRecords();
});
$("#saveRecords").click(function() {
SaveRecords();
});
});
function AddColumnRecords() {
var columnRecords="<tr><td>" + $("#columnName").val() + "</td><td>" + $("#type").val() +"</td><td>"+ document.getElementById('primaryCheck').checked+ "</td></tr>";
$("#ColumnTable").last().append(columnRecords);
$("#columnName").val(" ");
}
function SaveRecords() {
var Columns = new Array();
$("#ColumnTable").find("tr:gt(0)").each(function(){
var name=$(this).find("td:eq(0)").text();
var type=$(this).find("td:eq(1)").text();
var isPrimary=$(this).find("td:eq(2)").text();
var ColumnModel={};
ColumnModel.Name = name;
ColumnModel.Type = parseInt(type);
ColumnModel.IsPrimaryKey = isPrimary;
Columns.push(ColumnModel);
});
var Table={};
var tableName=$("#tableName").val();
Table.TableName=tableName;
Table.Columns=Columns;
console.log(JSON.stringify(Table));
$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data:{table : JSON.stringify(Table)},
success:function(data){alert("success")},
error:function(){alert("error")}
});
}
我的table是:
public class Table
{
public string TableName { get; set; }
public List<Column> Columns { get; set; } = new List<Column>();
}
列模型 class 是:
public class Column
{
public string Name { get; set; }
public virtual Types Type { get; set; } = Types.String;
public virtual bool IsPrimaryKey { get; set; } = false;
}
这是操作方法:
[HttpPost]
public IActionResult CreateTable([FromBody] Table table)
{
return View();
}
console log
<div class="mb-3">
<label for="tableName" class="form-label">Table Name</label>
<input type="text" class="form-control" id="tableName" aria-describedby="tableName">
</div>
<form>
<div class="mb-3">
<label for="columnName" class="form-label">Name</label>
<input type="text" class="form-control" id="columnName" aria-describedby="columnName">
</div>
<div class="mb-3">
<select class="form-select" aria-label="Default select example" id="type">
@{
<option value=3>@DatabaseSample.Models.Types.String</option>
<option value=0>@DatabaseSample.Models.Types.Integer</option>
<option value=5>@DatabaseSample.Models.Types.Boolean</option>
<option value=4>@DatabaseSample.Models.Types.Char</option>
<option value=2>@DatabaseSample.Models.Types.Double</option>
<option value=1>@DatabaseSample.Models.Types.Float</option>
<option value=6>@DatabaseSample.Models.Types.Date</option>
}
</select>
</div>
<div class="mb-3 form-check">
<input type="checkbox" class="form-check-input" id="primaryCheck">
<label class="form-check-label" for="exampleCheck1">Primary key</label>
</div>
</form>
<button id="addColumn" type="submit" class="btn btn-primary">Submit</button>
<table class="table" id="ColumnTable">
<thead>
<tr>
<th scope="col">Column name</th>
<th scope="col">Type</th>
<th scope="col">Primary key</th>
</tr>
</thead>
</table>
<button id="saveRecords" type="submit" class="btn btn-primary">Save</button>
删除 [FromBody] 并试试这个
let Table = {
TableName: $("#tableName").val(),
ColumnsStr :JSON.stringify(Columns)
//create a new property in Table model, calls ColumnsStr which will receive ColumnsStr
};
$.ajax({
type:'POST',
dataType:'json',
contentType:'application/json; charset=utf-8',
url:'@(Url.Action("CreateTable", "table"))',
data:Table,
success:function(data){alert("success")},
error:function(){alert("error")}
});
在控制器中你可以这样做:
table.Columns = JsonSerializer.Deserialize<List<Column>>(table.ColumnsStr)
在您的 ajax 发送代码中,您将模型转换为字符串!
$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data:{table : JSON.stringify(Table)}, // <<------------- HERE
success:function(data){alert("success")},
error:function(){alert("error")}
});
这意味着你发送这样的模型; { table: "..."}
但是您的控制器需要 Table 模型。
解决方案的第一个选项;不要通过 JSON.stringfy()
转换为字符串$.ajax({
type:'POST',
dataType:'JSON',
contentType:'application/json; charset=utf-8',
url:'/table/createtable',
data: Table, // <<------------- HERE
success:function(data){alert("success")},
error:function(){alert("error")}
});
或者第二个选项;将控制器参数从 Table 更改为字符串。当你得到模型字符串时,然后在控制器函数中将其转换为 Table 模型。
[HttpPost]
public IActionResult CreateTable([FromBody] string table)
{
var mTable = new JavaScriptSerializer().Deserialize<Table>(table);
return View();
}
仅用于发送 table 使用此
data: JSON.stringify(Table)
下面是工作demo,大家可以参考一下
更改 ajax 如下所示:
...
var Table={};
var tableName=$("#tableName").val();
Table.TableName=tableName;
Table.Columns=Columns;
console.log(JSON.stringify(Table));
$.ajax({
url:'/Home/Createtable',
type:'POST',
data:Table,
success:function(data){alert("success")},
error:function(){alert("error")}
});
在家庭控制器中:
public IActionResult Index()
{
return View();
}
[HttpPost]
public JsonResult CreateTable(Table table, List<Column> Columns)
{
var ccc = 0; // do your staff...
return Json(ccc);
}
结果: