如何在ExtJS(和Sencha架构师)的GridPanel中显示嵌套对象?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在ExtJS(和Sencha架构师)的GridPanel中显示嵌套对象?相关的知识,希望对你有一定的参考价值。

我有一个传入的Provide对象数组,如下所示:

[{
  "id" : 16,
  "price" : 500,
  "quantity" : 2000,
  "denomination" : "case",
  "denominationPlural" : "cases",
  "product" : {
    "id" : 14,
    "description" : "This is the text description for product 14."
  }
}, {
  "id" : 18,
  "price" : 500,
  "quantity" : 1,
  "denomination" : "study",
  "denominationPlural" : "studies",
  "product" : {
    "id" : 17,
    "description" : "This is a text description for product 17."
  }
}]

产品是产品乘以价格的数量。

现在我想在GridPanel中显示这些产品,但也包括这些行中的嵌套产品信息。以下是我之前的做法:

Ext.define('Offering', {
            extend: 'Ext.data.Model',
            fields: [
                {name: 'id', type: 'number'},
                {name: 'price', type: 'number'},
                {name: 'quantity', type: 'number'},
                {name: 'denomination', type: 'string'},
                {name: 'denominationPlural', type: 'string'},
                {name: 'product.description', type: 'string'},
            ]
        });



var offeringStore = Ext.create('Ext.data.Store', {
             autoDestroy: true,
             model: 'Offering',
             proxy: {
                 type: 'ajax',
                 url: '/offerings',
                 reader: {
                     type: 'json',
                     root: 'success'
                 }
             },
             autoLoad:true
         });

var offeringGrid = Ext.create('Ext.grid.Panel', {
            store: offeringStore,
            columns: [{
                    header: 'id',
                    dataIndex: 'id'
                }, {
                    header: 'price',
                    dataIndex: 'price'
                }, {
                    header: 'quantity',
                    dataIndex: 'quantity'
                }, {
                    header: 'denomination',
                    dataIndex: 'denomination'
                }, {
                    header: 'description',
                    dataIndex: 'product.description'
                },
            };

这工作得很好。然后,在某个地方(包括升级到ExtJS 5.1.1(来自ExtJS 4.2.1)和使用Sencha Architect,它破了。

问题1:Sencha Architect阻止在产品模型中为“product.description”创建一个条目,抱怨“。”字符。但是如果你把它创建为“whateveryouwant”,你可以进入模型领域并将其重命名为“product.description”。

问题2:解决“。”问题后。发出并运行应用程序时,“product.description”列的单元格为空白。

问题3:javascript控制台产生零错误。传入的数据看起来很好。

我该怎么做才能显示这个嵌套数据?

答案

我这样做很简单。只需将mapping属性添加到模型中:

{
    name: 'product.description', 
    type: 'string',
    mapping : 'product.description'
}

不需要renderer

另一答案

我当前的解决方法可以帮助处于相同情况的其他人,使用“渲染器”子句来显示所需的信息。

{
    xtype: 'gridpanel',
    title: 'Offerings',
    bind: {
        store: '{OfferingsStore}'
    },
    columns: [
            ...
            {
                xtype: 'gridcolumn',
                renderer: function(value, metaData, record, rowIndex, colIndex, store, view) {
                    return record.getData().product.description;
                },
                text: 'Product Description'
            },
            ...
      ]

但是我还是想在开发模型定义中使用“product.description”而不是这个渲染技巧。

以上是关于如何在ExtJS(和Sencha架构师)的GridPanel中显示嵌套对象?的主要内容,如果未能解决你的问题,请参考以下文章

Sencha 架构师使用 Ext.ux.ToolbarDroppable

如何在 sencha touch 或架构师中获取设备语言

[ExtJS5学习笔记]第三十四节 sencha extjs 5 grid表格之java后台导出excel

如何删除EXTJS中特定行的汇总分组

如何冻结/锁定 ExtJs 网格中的单行?

Sencha 架构师可以使用模板成员函数吗?