我有一个带有模板的 kendo ui listview,它根据基础数据有条件地隐藏元素。一个例子如下:
<script type="text/x-kendo-template" id="template">
<div class="product">
<img src="../content/web/foods/#= ProductID #.jpg" alt="#: ProductName # image" />
<h3>#:ProductName#</h3>
<p>#:kendo.toString(UnitPrice, "c")#</p>
<div>
# if (Discontinued) { #
Discontinued Product
# } #
</div>
</div>
</script>
如果我使用以下代码修改基础数据源项以设置 Discontinued:
data[index].set('Discontinued', true);
如果索引是当前选定的项目,则该项目失去焦点并且不再被选中。
请参阅以下 dojo 示例http://dojo.telerik.com/UlOze,从列表中选择一个项目,然后将其设置为已停止。
有没有人找到这个问题的解决方案/解决方法?
谢谢。
------------- 最终解决方案 --------------
根据下面的 dimodi 的回答,我将解决方案拼凑在一起。为此,dataSource 必须设置 schema -> model -> id 属性。
第一次捕获当前选择的数据项:
var selectedItem = $(listElement).find(".k-state-selected");
var selectedDataItem = list.dataItem(selectedItem);
2nd:调用 .set 后重新查找数据项并设置 k-state-selected 类。这是必要的,因为列表组件正在重新生成 uid。
if (selectedDataItem) {
var newSelectedItem = list.dataSource.get(selectedDataItem.ProductID)
var uid = newSelectedItem.uid;
jQuery("[data-uid='" + uid + "']").addClass("k-state-selected");
}
我已经更新了原来的 dojo 来展示这个解决方案,以防它帮助别人。