首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >extjs5嵌套网格(表:子表)

extjs5嵌套网格(表:子表)
EN

Stack Overflow用户
提问于 2014-08-08 09:45:51
回答 1查看 3K关注 0票数 1

实际上,我有两张桌子(梅纳扎和萨尔瓦多),第一张表显示的是闭经,第二张是萨尔瓦多。每个萨尔瓦多都与任何闭锁相关联,所以我想在每一行中显示另一个子表(使用萨尔瓦多表),使用rowExpand和ExtJS5。类似于这个例子。如何使用salvaguardaStore插入另一个网格,只显示与该行的闭门性相关的萨尔瓦多?(类似于客户-购买)下面是代码:

代码语言:javascript
复制
 //MODEL
    // AMENAZAS
Ext.define('Amenazas', {
    extend: 'Ext.data.Model',
    fields: [ 'id', 'codigo', 'denominacion', 'a_impacto', 'a_riesgo','c_impacto', 'c_riesgo','i_impacto', 'i_riesgo', 'd_impacto', 'd_riesgo','t_impacto', 't_riesgo','total_impacto', 'total_riesgo',]
});

    // SALVAGUARDAS
Ext.define('Salvaguardas', {
    extend: 'Ext.data.Model',
    fields: [ 'id_amenaza','tipo','modo', 'codigo','denominacion', 'eficiencia',]
});

DataStore (在我的DB Amenaza.id = Salvaguardas.id_amenaza中,在每行创建1:n关联)

代码语言:javascript
复制
// DATASTORE
    //AMENAZAS
var amenazaStore = Ext.create('Ext.data.Store', {
    model: 'Amenazas',
    data: [
        { id: 1, codigo: 'E.1', denominacion: 'Errores de los usuarios', a_riesgo: '0', c_riesgo: '0', i_riesgo: '0', d_riesgo: '1015875', t_riesgo: '0',  total_riesgo: '1015875'},
        { id: 2, codigo: 'E.5', denominacion: 'Deficiencias en la organización', a_riesgo: '0',  c_riesgo: '0',  i_riesgo: '0',  d_riesgo: '526750',  t_riesgo: '0',  total_riesgo: '526750'},
        { id: 3, codigo: 'E.8', denominacion: 'Escapes de información',  a_riesgo: '0', c_riesgo: '0',  i_riesgo: '0',  d_riesgo: '752500', t_riesgo: '0',  total_riesgo: '752500'},
        { id: 4, codigo: 'E.9', denominacion: 'Alteración accidental de la información',  a_riesgo: '0',  c_riesgo: '0',  i_riesgo: '0',  d_riesgo: '376250',  t_riesgo: '0',  total_riesgo: '376250'}
    ]
});

    //SALVAGUARDAS
    var salvaguardaStore = Ext.create('Ext.data.Store', {
    model: 'Salvaguardas',
    data: [
        { id_amenaza: 1, tipo: 'Correctiva', modo: 'Correctiva', codigo: 'corr-01', denominacion: 'correctiva 1', eficiencia: 'MB' }
 ]
});

网格使用rowExpander展开每一行并显示信息,我想在rowExpand中显示第二个表和他自己的萨尔瓦多。

代码语言:javascript
复制
//GRIDPANEL
Ext.create('Ext.grid.Panel', {
    renderTo: 'example-grid',
    store: amenazaStore,
    width: 980,
    height: 790,
    title: '<bean:write name="informesAGRForm" property="nombreActivo"/>',
    plugins: [
              {
        ptype: 'rowexpander',
        rowBodyTpl : new Ext.XTemplate(
            '<p><b>Denominación:</b> {denominacion}</p>',
            '<p><b>Código:</b> {codigo}</p><br>',
            '<p><b>Riesgo Total:</b> {total_riesgo}</p>')
              }
    ],
    collapsible: false,
    animCollapse: false,
    columns: [
        {
            text: 'ID',
            hidden: true,
            hideable: false,
            dataIndex: 'id'
        },   
        {
            text: 'Codigo',
            width: 50,
            sortable: true,
            hideable: false,
            dataIndex: 'codigo'
        },          
        {
            text: 'Denominación',
            width: 150,
            dataIndex: 'denominacion',
        },
        {
            text: ' Autenticidad',
            flex: 1,
            dataIndex: 'a_riesgo'
        },
        {
            text: 'Confidencialidad',
            flex: 1,
            dataIndex: 'c_riesgo'
        },
        {
            text: 'Integridad',
            flex: 1,
            dataIndex: 'i_riesgo'
        },
        {
            text: 'Disponibilidad',
            flex: 1,
            dataIndex: 'd_riesgo'
        },
        {
            text: 'Trazabilidad',
            flex: 1,
            dataIndex: 't_riesgo'
        },
        {
            text: 'Total',
            flex: 1,
            dataIndex: 'total_riesgo'
        }]
    });

提前谢谢你

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-13 09:26:17

其实很容易。您应该在项目中包括子表插件(您可以从http://dev.sencha.com/extjs/5.0.0/examples/ux/grid/SubTable.js下载它)。然后将其配置如下:

代码语言:javascript
复制
{
    ptype: "subtable",
    headerWidth: 24,
    columns: [{
        text: 'id_amenaza',
        dataIndex: 'id_amenaza',
        width: 100
    }, {
        width: 100,
        text: 'codigo',
        dataIndex: 'codigo'
    }],
    getAssociatedRecords: function(record) {
        var result = Ext.Array.filter(
            salvaguardaStore.data.items,
            function(r) { return r.get('id_amenaza') == record.get('id'); }
        );
        return result;
    }
}

最重要的是getAssociatedRecords覆盖。必须返回要显示的记录数组,这样基本上可以过滤salvaguardaStore数据。

工作样本:http://jsfiddle.net/7czs02yz/11/

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25200529

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档