2017-03-27 16 views
2

ノックアウトのビューモデルをコントローラに投稿する簡単な例を使用しています。しかし、それは起こっていません。コントローラのdogメソッドがnullになっています。knockout.js viewmodel asp.netでバインディングされていません投稿用のmvcコントローラ

私は間違っていますか?

マイモデル

public class Dog 
{ 
    public string name { get; set; } 
    public int age { get; set; } 
} 

私のコントローラがするDogオブジェクトがnull

[HttpPost] 
public ActionResult Save(Dog dog) 
{ 
    return Json(new { Status = string.Format("Success, saved {0} with age: {1}", dog.name, dog.age) }); 
} 

ビュー

<form method="POST" data-bind="submit: save"> 
    <div>Name:</div> 
    <div><input type="text" data-bind="value: name" /></div> 

    <div>Age:</div> 
    <div><input type="text" data-bind="value: age" /></div> 

    <div><input type="submit" value="Save" /></div> 
</form> 


var ViewModel = function (data) { 
    var self = this; 
    ko.mapping.fromJS(data, {}, self); 

    //self.isValid = ko.computed(function() { 
    // return self.name().length > 0; 
    //}); 

    self.save = function() { 
     $.ajax({ 
      url: "Home/Save", 
      type: "post", 
      contentType: "application/json", 
      data: ko.mapping.toJSON(self), 
      success: function (response) { 
       alert(response.Status); 
      } 
     }); 
    }; 
}; 
+0

フォームからか、Ajaxのポストを介してデータを投稿しようとしていますか? save関数へのバインディングがないためです。 – muhihsan

+1

〜ajax投稿 – maztt

+0

私はオブジェクトを送信する必要があると思います – maztt

答えて

1

を取得してみてください追加する[FromBody]属性

HTMLおよびJavaScriptに次の
[HttpPost] 
public ActionResult Save([FromBody]Dog dog) 
{ 
    return Json(new { Status = string.Format("Success, saved {0} with age: {1}", dog.name, dog.age) }); 
} 

てみませんか は

<div>Name:</div> 
<div><input type="text" data-bind="value: name" /></div> 

<div>Age:</div> 
<div><input type="text" data-bind="value: age" /></div> 

<div><button data-bind="click: save">Save</button></div> 

<script> 
    var ViewModel = function() { 
    var self = this; 
    self.name = ko.observable(); 
    self.age = ko.observable(); 

    self.save = function() { 
     var jsonData = {'name': self.name(), 'age': self.age()}; 
     $.ajax({ 
      url: "http://localhost:8000/home/saves", 
      type: "post", 
      contentType: "application/json", 
      data: jsonData, 
      success: function (response) { 
       alert(response.Status); 
      } 
     }); 
    }; 
    }; 

    ko.applyBindings(new ViewModel()); 
</script> 
+0

return XML解析エラー:ルート要素が見つかりません場所:moz-nullprincipal:{5403ac24-a9c4-4147-81c4-71d71452b173}行番号1、列1: – maztt

+0

これを送信すると、var data = { name: "age"、 年齢:23 }; – maztt

+0

私は結果を修正しました。これは私と一緒に働いています – muhihsan