ExtJS 将 link 放在树面板的树列中

ExtJS Put link in tree column of a tree panel

我想把 link 放在树面板的树列中,实际上我可以把我想要的 link 放在列中,但是 link 出现了文件夹和我在另一列中的复选框,我的问题是如何删除这些元素并维护 link?

我有这个代码:

这是树面板的视图:

    initComponent: function() {
    var anchoPanatallaRes = window.screen.width;
    var altoPantallaRes = window.screen.height;

    var anchoTOC = 330;
    var altoTOC = 473;

    if (anchoPanatallaRes <= 1024) {
        anchoTOC = 282;
        altoTOC = 373;
    }
    var treeStore = Ext.getStore('capa');

    function addUrl(value, p, record) {
        return value ? Ext.String.format(
                '<a href="'+value+'"target="_blank"'+'>Ver metadato'+'</a>'
        ):'';
    }

    var tree = Ext.create('Ext.tree.Panel', {
        title: '',
        width: anchoTOC,
        height: altoTOC,            
        reserveScrollbar: true,
        loadMask: true,
        useArrows: true,
        rootVisible: false,
        store: 'capa',
        allowDeselect : true,
        border : true,
        animate: true,
        listeners: {
            checkchange: function(node, checked, eOpts) {
                console.log('nodo seleccionado:', node, checked, eOpts);
            }
        },
        columns: [{
            xtype: 'treecolumn',
            text: 'Capa',
            flex: 4,
            sortable: true,
            dataIndex: 'nombre'
        },{
            xtype: 'treecolumn',
            text: 'Metadato',
            flex: 2,
            dataIndex: 'url',
            renderer: addUrl
        }],

        tbar: [{
            labelWidth: 100,
            xtype: 'triggerfield',
            fieldLabel: 'Nombre capa:',
            triggerCls: 'x-form-clear-trigger',
            onTriggerClick: function() {
                this.reset();
                treeStore.clearFilter();
                this.focus();
            },
            enableKeyEvents: true,
            listeners: {
                keyup: function() {
                    var field = tree.down('textfield'),
                    v;

                    try {
                        v = new RegExp(field.getValue(), 'i');
                        treeStore.filter({
                            filterFn: function(node) {
                                var children = node.childNodes,
                                len = children && children.length,

                                //Visibilidad de los hijos 
                                visible = node.isLeaf() ? v.test(node.get('nombre')) : false,   i;

                                //Visibilidad de los padres
                                for (i = 0; i < len && !(visible = children[i].get('visible')); i++);

                                return visible;
                            },
                            id: 'campoFiltroCapa'
                        });
                    } catch (e) {
                        field.markInvalid('Expresión no valida');
                    }
                },
                buffer: 250
            }
        }]
    });

    Ext.apply(this, {
        title: 'TABLA CONTENIDO',
        id: 'ventanaCapas',
        constrain: true,
        header : {
            titlePosition : 2,
            titleAlign : 'center'
        },
        closable : false,
        width : anchoTOC,
        height : altoTOC,
        x : 20,
        y : 270,
        layout : 'fit',
        animCollapse : true,
        collapsible : true,
        collapseDirection : Ext.Component.DIRECTION_LEFT,
        listeners : {
            collapse : function(p) {
            }
        },
        items: [tree],
    });
    this.callParent(arguments);
}

型号:

Ext.define('app.model.modeloCapa', {
extend: 'Ext.data.Model',
fields: ['nombre','url'],

proxy: {
    type: 'ajax',
    url: "data/jsontestqmodel.json",  
    reader: {
        type    : 'json',
        root    : 'Result',
    }
}});

店铺:

Ext.define('app.store.capa', {
extend: 'Ext.data.TreeStore',
requires: 'app.model.modeloCapa',
model: 'app.model.modeloCapa'
});

以及我正在使用的 JSON 文件:

{"Result": [{
"nombre": "Transporte Marítimo Fluvial",
"id": 74,
"Result": [{    
        "id": 268,
        "titulo": "puerto_p_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "puerto_p_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
}]},{
"nombre": "Entidades Territoriales y Unidades Admin",
"id": 65,
"Result": [{
        "id": 239,
        "titulo": "limite_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "limite_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 319,
        "titulo": "administrativo_p_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "administrativo_p_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
    }
]},{
"nombre": "Instalaciones Construcciones para el Transporte",
"id": 67,
"Result": [{
        "id": 269,
        "titulo": "red_alta_tension_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "red_alta_tension_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false

},{
        "id": 260,
        "titulo": "peaje_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "peaje_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false

},{
        "id": 275,
        "titulo": "torre_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "torre_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 266,
        "titulo": "puente_l_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "puente_l_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 267,
        "titulo": "puente_p_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "puente_p_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{

        "id": 259,
        "titulo": "paso_nivel_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "paso_nivel_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 223,
        "titulo": "antena_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "antena_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 273,
        "titulo": "terminal_p_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "terminal_p_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 265,
        "titulo": "poste_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "poste_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
},{
        "id": 276,
        "titulo": "tuberia_25k",
        "url": "http://172.17.2.157:8080/geoserver/sigtierras/wms",
        "nombre": "tuberia_25k",
        "metadato": "",
        "wfs": false,
        "leaf": true,
        "checked": false
}]
}]
}

只需删除第二个 treecolumn 上的 xtype。它将默认为 gridcolumn,因此它看起来像一个普通的网格列。