Rally SDK 2.0 RallyGrid在单击页面时给出IndexOf错误

时间:2012-06-14 04:20:43

标签: javascript extjs rally

我有一个只有3个项目的拉力赛网格。网格自动显示每页显示25/50/100 / etc的链接。当我点击50时,比如说,我只是得到一个持续的微调器,说“正在加载......”,在JS控制台中,我得到一个未被捕获的错误“无法调用方法'indexOf'......”

我假设这意味着我的数据存储丢失了什么?

这是网格内容:

        var resultsModel = Ext.define('ResultsModel', {
            extend: 'Ext.data.Model',
            fields: [
            {name: 'FID', type: 'string'},
            {name: 'TestName', type: 'string'},
            {name: 'TestDuration', type: 'string'},
            {name: 'Verdict', type: 'string'},
            ]       
        });

this.resultsStore = Ext.create('Ext.data.Store',{                         model:'ResultsModel',                         pageSize:25                     });

        this.down('#testResults').add({
                xtype: 'rallygrid',
                store: this.resultsStore,
                width: 800,
                viewConfig: {
                stripeRows: true,
                emptyText: "No test cases run"
                },
                columnCfgs: [
                    {
                        text: 'TestCase', dataIndex: 'FID', width: 65 
                    },
                    {
                        text: 'Test Name', dataIndex: 'TestName', flex: 1
                    },
                    {
                        text: 'Run Time (s)', dataIndex: 'TestDuration', width: 75
                    },                      
                    {
                        text: 'Verdict', dataIndex: 'Verdict', width: 65, 
                        renderer: function(value){
                            if((value == "Fail") || (value == "Error")){
                                return Ext.String.format("<div style='background-color:#F00;color:#FFF;font-weight:bold;text-align:center'>{0}</div>", value);
                            }
                            else{
                                return Ext.String.format("<div style='background-color:#2EFE2E;color:#000;font-weight:bold;text-align:center'>{0}</div>", value);

                            }
                        }
                    }

                ]
            });

这里的数据被推入数据存储区:

    Ext.Array.each(data, function(record) {     
        records.push({
            FID: record.get('TestCase')['FormattedID'],  //record.data.TestCase might work too.
            TestName: record.get('TestCase')['Name'],
            TestDuration: record.get('Duration'),
            Verdict: record.get('Verdict')
        });
    });

    this.resultsStore.loadData(records, false);

Ext迭代的数组中的数据只是测试运行的一部分。

这是控制台输出:

Uncaught TypeError: Cannot call method 'indexOf' of undefined sdk-debug.js:5304
Ext.apply.urlAppend sdk-debug.js:5304
Ext.define.buildUrl sdk-debug.js:26016
Ext.define.buildRequest sdk-debug.js:25859
Ext.define.doRequest sdk-debug.js:26059
Ext.define.read sdk-debug.js:25828
Ext.define.load sdk-debug.js:44668
Base.callParent sdk-debug.js:2894
Ext.define.load sdk-debug.js:45283
Ext.define.read sdk-debug.js:44420
Ext.define.loadPage sdk-debug.js:45562
Ext.define.changePageSize sdk-debug.js:96872
(anonymous function) sdk-debug.js:1540
(anonymous function)
wrap

1 个答案:

答案 0 :(得分:0)

你见过这个例子吗?

https://rally1.rallydev.com/apps/2.0p/doc/#!/example/GridWithFreeformData

我们创建了一个与网格相匹配的商店,它会自动创建模型并为您加载自定义数据。