0

我想将 FeatureList (observableArray) 中的数据传递给 TreeController 中的 SaveMappings 函数。我已将一个按钮绑定到 sendItems 函数。我在 var data=p2fData 行放了一个断点,看看我收到了什么。p2fData 为空。

我将控制器更改为公共 JsonResult SaveMappings(List p2fData)。在这种情况下,p2f 数据显示有 1 个元素,但它也为空。

var Feature = function (featId) {
    var self = this;
    self.featId = featId;    
    self.parameters = ko.observableArray();    
}

var ParameterToFeatureListViewModel = function () {
    var self = this;
    var newFeature = new Feature("Feature XYZ");
    newFeature.parameters.push("1");
    newFeature.parameters.push("2");
    self.FeatureList = ko.observableArray([newFeature]);
    self.sendItems = function() {
        $.ajax({
           type: "POST",
           url: '/Tree/SaveMappings',
           data: ko.toJSON(self.FeatureList),
           contentType: "application/json; charset=utf-8",
           dataType: "json",
           success: function (response) {
               alert(response);
           },
           error: function (request, status, error) {
               alert(request.statusText);
           }
        });
    }
}

var vm = new ParameterToFeatureListViewModel()
ko.applyBindings(vm);

public class TreeController:Controller
{
    public ActionResult Index(){...}
    [HttpPost]
    public JsonResult SaveMappings(string p2fData)
    {
        var data = p2fData;
        return Json(data);
    }
}
4

1 回答 1

0

Please have a look @ how to pass knockoutjs view model into a mvc controller ... May be it helps..

于 2013-03-20T20:35:46.063 回答