【发布时间】:2016-05-22 18:03:33
【问题描述】:
我正在使用淘汰赛来修改用户界面。我可以选择通过单击每个文本上的关闭按钮“x”来从屏幕上删除文本。
当我点击保存时,我希望所有剩余的文本都保留在屏幕上,没有关闭按钮,也没有文本周围的输入框。我怎样才能通过淘汰赛实现这一目标。我的代码如下
var data = { Name: "Test",
Items: ["sample1", "sample2", "sample3","DESIGN"]
};
function ViewModel(data) {
var self = this;
self.Name = ko.observable(data.Name);
self.Items = ko.observableArray(ko.utils.arrayMap(data.Items, function(item) {
return { value: ko.observable(item) };
}));
self.addItem = function() { self.Items.push({ value: ko.observable("") }); };
self.removeItem = function(data) {
self.Items.remove(data);
};
self.SaveItem = function() { self.Items.push({ value: ko.observable("") }); };
self.SaveItem = function(data) {
self.Items.save(data);
};
}
$(document).ready(function() {ko.applyBindings(new ViewModel(data)); });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.0.0/knockout-min.js"></script>
<div>
Name: <span data-bind="text: Name"></span>
</div>
<div>
Items: <button data-bind="click: addItem">Add Item</button>
</div>
<div>
<table>
<tbody data-bind="template: { name: 'itemTemplate', foreach: Items }"></tbody>
</table>
</div>
<button data-bind="click: SaveItem">SAVE</button>
<script type="text/html" id="itemTemplate">
<tr>
<td>
<input data-bind="value: value" />
<a href="#" data-bind="click: $parent.removeItem">X</a>
</td>
</tr>
</script>
【问题讨论】:
-
我冒昧地稍微更改了您问题中的 sn-p,因为它已损坏。如果我的更改有误,请务必还原。
-
不知道为什么它看起来坏了。我试图让用户单击保存时,关闭按钮与输入框一起消失,但文本仅保留在屏幕上。
标签: jquery knockout.js