如何从ListItem调用ListView

时间:2013-02-26 13:17:24

标签: javascript windows-8 visual-studio-2012 microsoft-metro winjs

我想在右侧列表中的任何项目时更新右侧listview 此外,当我单击选择所有项目以选择右侧列表项而不是左侧项目时。

换句话说,

我想要做的是,当我点击左侧列表中的任何项目时,右侧列表将根据我调用的左侧项目更改为不同的列表

enter image description here

这是我的JS代码

function selectionChangedHandler() {

    // Check for selection
    var selectionCount = listView.selection.count();
    if (selectionCount === 1) {

        // Only one item is selected, show the message
        // information for the item
        listView.selection.getItems().done(function (items) {
            // Print item data to the relevant message pane locations
            inboxMessage_Text.innerText = items[0].data.text;
            if (items[0].data.key == 1) {
                document.getElementById('listView4b2')
                        .innerHTML = '<ol><li>html2222 data</li></ol>';
            } else {
                document.getElementById('listView4b2')
                        .innerHTML = '<ol><li>html data</li></ol>';
            }
        });

    }

}
function selectAll() {
    WinJS.log && WinJS.log(" ", "sample", "status");
    listView.selection.selectAll();
}

function clearSelection() {
    WinJS.log && WinJS.log(" ", "sample", "status");
    listView.selection.clear();
}

和HTML代码

<div id="listView4b"
    class="win-selectionstylefilled"
    data-win-control="WinJS.UI.ListView" 
    data-win-options="{ 
        itemDataSource: myToppingsData.dataSource, 
        itemTemplate: mediumListIconTextTemplate, 
        selectionMode: 'multi', 
        tapBehavior: 'toggleSelect', 
        layout: { type: WinJS.UI.GridLayout } 
    }"
></div>

1 个答案:

答案 0 :(得分:0)

假设myToppingsData是WinJS.Binding.List,在左itemInvoked的{​​{1}}处理程序中使用createFiltered在此列表中创建投影。

然后,您可以将右侧列表的WinJS.UI.ListView设置为此过滤后的列表dataSource。