目标:让用户能够调整映射结果。
我遇到了一个问题,我需要实际更改数据绑定元素使用的实例。免责声明:我的 json 数据结构可能已关闭,我愿意接受可能的修改。我正在编写一个表头映射应用程序,以便用户可以验证服务器映射的标题是否正确。如果出现问题,用户将能够映射标题。I have not been able to figure out how to actually update the data bound to the result when the select menu is changed. 感觉应该超级简单。我一直发现自己基本上是一个完成的淘汰赛应用程序,而不是最后一步......
标记片段:
<div id="wrapper" data-bind="foreach: headings">
<h1>Bind from this</h1>
<select data-bind="value: selectMenuIdVal, event: { change: updateListing }">
<option> </option>
<!-- ko foreach: $root.headings -->
<option data-bind="value: $data.CC_FIELD_ID, visible: $data.VENDOR_FIELD_NAME(), text: $data.VENDOR_FIELD_NAME"></option>
<!-- /ko -->
</select>
<h1>To this</h1>
<ul data-bind="foreach: listingFields">
<li data-bind="text: $data.VALUE"></li>
</ul>
</div>
KO片段:
var Heading = function(data) {
var self = this;
var heading = ko.mapping.fromJS(data, {}, this);
heading.selectMenuIdVal = ko.observable(heading.CC_FIELD_ID());
// heading.listingFields gets mapped by the mapping plugin
this.updateListing = function(ko_evt, js_evt) {
//TODO
// Get the listing results from the value of the select menu
// self.listingFields(those listings);
}
return heading;
}
这是我的小提琴:http: //jsfiddle.net/breck421/SLT9B/1/