【发布时间】:2015-05-29 20:36:46
【问题描述】:
我在敲除模板中有一个隐藏字段,它的值使用 jquery 更新。问题是当尝试使用 ajax 将此值传递给服务器时,我在控制器中得到空值。但是html源码显示隐藏字段的值是更新的。如果我将隐藏字段替换为文本框,则只有在我手动输入文本时才能正常工作。
jQuery
function getFileDetail(fileID, fileName) {
$('#hdnFileName' + fileID).val(fileName);
$('#lblFileName' + fileID).text(fileName);
}
这里是 html 敲除模板:
<script type="text/html" id="fileTemplate">
<div data-role="fieldcontain">
<a href="#" data-bind="click: function () { openFileUpload('file', ID) }"><label data-bind="text: 'File Upload ' + ID, attr: { id: 'lblFileName' + ID }"></label></a><input type="button" value="Remove" data-bind="click: removeFile" />
</div>
<input type="hidden" name="hdnFileName" data-bind="attr: { id: 'hdnFileName' + ID, value: fileName }" />
</script>
视图模型
function FileViewModel() {
var self = this;
self.ID = ko.observable();
self.fileName = ko.observable();
self.removeFile = function (file) { };
self.Files = ko.observableArray([{ ID: 1, fileName: "", removeFile: function (file) { self.Files.remove(file); }}]);
self.addNewFile = function () {
var newFile = new FileViewModel();
newFile.ID = self.Files().length + 1;
newFile.fileName = "";
newFile.removeFile = function (file) { self.Files.remove(file); };
self.Files.push(newFile);
//$("input[name='hdnFileName'").trigger("change");
}
}
function ViewModel() {
var self = this;
self.fileViewModel = new FileViewModel();
self.submitForm = function () {
$.ajax({
type: "POST",
url: "<%= Url.Action("MeetingPresenter")%>",
data: "{Files:" + ko.utils.stringifyJson(self.fileViewModel.Files) + "}",
contentType: "application/json",
success: function (data) {},
});
};
}
【问题讨论】:
-
在哪里插入带有
jQuery的值? -
您使用 attr 绑定来绑定值似乎很奇怪。您不使用值绑定是否有原因?
-
@adricadar 我刚刚添加了 jQuery
标签: ajax knockout.js data-binding hidden-field