我已经在.NET中定义了一个对象类型,我想在列表<>中作为ASP.NET MVC操作方法的输入接收该对象类型?如何将对象列表传递给使用jQuery的ASP.NET MVC操作?
这里是我试图接收的操作方法和类。
public class WhereClause
{
public string ColumnInformation { get; set; }
public string WhereValue { get; set; }
public string AndOr { get; set; }
public string Comparer { get; set; }
}
public ActionResult Grid(string query, int skip = 0, int take = 50, List<WhereClause> whereClauses = null)
{
GridViewModel gvm = new GridViewModel();
gvm.Query = query;
而且这里是我从一组使用jQuery表行建立的集合,然后调用jQuery的阿贾克斯()方法中的JavaScript。
var whereClauses = [];
// Iterate over every row in the table and pull the values fromthe cells.
divQueryWidget.find('.tblWhereClauses tr').each(function (x, y) {
var tds = $(y).find('td');
var columnInformation = $(tds[0]).html();
var whereValue = $(tds[1]).html();
var andOr = $(tds[2]).html();
var comparer = $(tds[4]).html();
// Create a whereClause object
var whereClause = {};
whereClause.ColumnInformation = columnInformation;
whereClause.WhereValue = whereValue;
whereClause.AndOr = andOr;
whereClause.Comparer = comparer;
whereClauses.push({
ColumnInformation: columnInformation,
WhereValue: whereValue,
AndOr: andOr,
Comparer: comparer
});
});
//divQueryWidget.find('#queryResultsGrid').
$.ajax({
type: 'GET',
url: '<%= Url.Action("Grid", "Query") %>',
dataType: 'html',
data: { query: divQueryWidget.find('#activeQuery').val(), whereClauses: whereClauses },
success: function (data, textStatus, XMLHttpRequest) { divQueryWidget.find('#queryResultsGrid').append(data); divQueryWidget.find('.loading').css('visibility', 'hidden'); }
});
这里是事情变得有趣的地方。调用javascript时,表中有两行应该传递给MVC操作,请注意,在调试代码时,如何在列表中创建两个对象,但其属性未填充。
我在做什么错的是我的防止Javascript对象被转换成.NET列表<>类型?我应该使用数组吗?我需要将某些东西标记为可序列化吗?