1

我在 Windows 8 Metro 应用程序中遇到嵌套 ListViews 的问题。我得到错误:

Exception was thrown at line 5840, column 33 in 
ms-appx://microsoft.winjs.1.0/js/base.js 0x800a138f - JavaScript runtime error: 
Unable to get property 'dataSource' of undefined or null reference

代码是:

<div id="color" data-win-control="WinJS.Binding.Template">
    <div>color</div>
</div>
<div id="row" data-win-control="WinJS.Binding.Template">
    <div>
        <div>row</div>
        <div 
            data-win-control="WinJS.UI.ListView"
            data-win-options="{ itemDataSource : colorsDataSource.dataSource, 
                    itemTemplate: select('#color')}">  
        </div>
    </div>
</div>
<div id="basicListView" 
    data-win-control="WinJS.UI.ListView"
    data-win-options="{ itemDataSource : Data.rowsDataSource.dataSource, 
            itemTemplate: select('#row')}">  
</div>

有问题的行是:

data-win-options="{ itemDataSource : colorsDataSource.dataSource, 
                    itemTemplate: select('#color')}"

问题是,在评估 data-win-options 时,colorsDataSource 不知何故无法访问 - 不知道为什么,因为数据结构 Data 是静态的,并且在 UI 甚至解析之前初始化(在 args.setPromise(WinJS .UI.processAll());)。

例如,当我尝试将模板修改为此:

<div id="row" data-win-control="WinJS.Binding.Template">
    <div>
        <div>row</div>
        <div data-win-bind="innerText: colorsDataSource.dataSource" ></div>
    </div>
</div>

它正确输出[object Object] ...

javascript 结构 Data 如下所示:

var rows = new WinJS.Binding.List([]);
model.rows.forEach(function (row) {
    rows.push({
       colorsDataSource : new WinJS.Binding.List(row.rowData.colors)
    });                
});
Data.rowsDataSource = rows;

编辑: 嗯,我找到了原因(base.js中属性data-win-options的处理):

var options;
var optionsAttribute = element.getAttribute("data-win-options");
if (optionsAttribute) {
    options = WinJS.UI.optionsParser(optionsAttribute, global, {
        select: createSelect(element)
    });
}

这些选项是在全局上下文中评估的,这意味着无法获取当前处理的项目(在我的情况下是项目)......

解决方法是创建自定义渲染器(整个自定义控件)。此处部分描述了http://stephenwalther.com/archive/2012/05/23/metro-dynamically-switching-templates-with-a-winjs-listview.aspx - 请参阅 itemTemplateFunction

4

2 回答 2

0

嵌套列表视图基本上不起作用并且不受支持。不幸的是,你不会找到一个简单的答案。

于 2012-11-04T18:46:34.983 回答
0

正如 Chris Tavares 所说,不支持嵌套的 ListView。

但是,这不起作用的更大原因是您需要了解如何在下一个控件上获取数据本身(暂时忽略它是一个列表视图)。

您已尝试使用该data-win-options属性解决此问题,正如您正确指出的那样,该属性仅解析为全局名称空间。

有一个解决方法——使用数据绑定

你在哪里:

<div data-win-control="WinJS.UI.ListView"
     data-win-options="{ itemDataSource : colorsDataSource.dataSource, 
     itemTemplate: select('#color')}">  
</div>

删除itemsDataSourcefrom data-win-options,并将其移至 data-win-bind:

<div  data-win-control="WinJS.UI.ListView"
      data-win-options="{ itemTemplate: select('#color')}"
      data-win-bind="winControl.itemDataSource: colorsDataSource.dataSource">  
</div>

这假定 colorsDataSource 是正在呈现的项目的属性。例如你的行对象。

为了解决您的嵌套问题,看起来您的“父”列表视图可能会消失——只需根据您的数据源动态创建元素。

于 2012-11-04T22:35:12.100 回答