ノックアウトを使用してフォームを休憩サービスに送信しようとしています。ボタンを押すとsubmit
、フォームはブラウザがクラッシュするまで無限ループに入ります。ここで何が起こっているのか本当に理解できません。
Javascript:
var viewModel;
var Subscription = function () {
var self = this;
self.Name = ko.observable('');
self.Email = ko.observable('');
self.submitForm = function () {
var viewModelJs = ko.toJS(ko.utils.unwrapObservable(viewModel));
$.ajax('/umbraco/surface/newsletter/AddSubscription', {
data: viewModelJs,
type: "POST",
async: true,
contentType: "application/json",
dataType: "json",
success: function (result) {
alert("sent");
},
error: function (error) {
if (window.console && console.log) {
console.log(error);
}
}
});
return false;
};
};
$(function () {
viewModel = new Subscription();
ko.applyBindings(viewModel);
});
そして、ここに私のフォームがあります:
<form class="form-horizontal" data-bind="submit: $root.submitForm">
<div class="control-group">
<label class="control-label" for="Name">Nombre</label>
<div class="controls">
@Html.TextBoxFor(m => m.Name, new { placeholder = "Nombre", data_bind = "value: Name" })
@Html.ValidationMessageFor(m => m.Name)
</div>
</div>
<!-- A couple more controls here -->
<div class="control-group">
<div class="controls">
<button type="submit" class="btn">Enviar</button>
</div>
</div>
</form>