ExtJs 实现动态列,动态多表头 在这里添加日志标题

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

先看看效果

ExtJs 实现动态列,动态多表头 在这里添加日志标题 - dingtao-wgs - 程序员驿站

效果不错吧,就是样式稍微差点,没办法Extjs的表头是渐变的,不过样式改起来应该不难.

接下来是数据:

"{columModle:[{header:\"用电单位\",dataIndex:\"用电单位\"},

{header:\"2009-06 _度数\",dataIndex:\"2009-06 _度数\"},

{header:\"2009-06 _单价\",dataIndex:\"2009-06 _单价\"},

 {header:\"2009-06 _金额\",dataIndex:\"2009-06 _金额\"},

 {header:\"2009-07 _度数\",dataIndex:\"2009-07 _度数\"},

 {header:\"2009-07 _单价\",dataIndex:\"2009-07 _单价\"},

 {header:\"2009-07 _金额\",dataIndex:\"2009-07 _金额\"},

{header:\"2009-08 _度数\",dataIndex:\"2009-08 _度数\"},

{header:\"2009-08 _单价\",dataIndex:\"2009-08 _单价\"},

 {header:\"2009-08 _金额\",dataIndex:\"2009-08 _金额\"},

 {header:\"合计_度数\",dataIndex:\"合计_度数\"},

 {header:\"合计_金额\",dataIndex:\"合计_金额\"}],

 fieldsNames:[{name:\"用电单位\"},{name:\"2009-06 _度数\"},{name:\"2009-06 _单价\"},{name:\"2009-06 _金额\"},{name:\"2009-07 _度数\"},

{name:\"2009-07 _单价\"},{name:\"2009-07 _金额\"},{name:\"2009-08 _度数\"},{name:\"2009-08 _单价\"},{name:\"2009-08 _金额\"},

{name:\"合计_度数\"},{name:\"合计_金额\"}],

 data:[{\"用电单位\":\"1\",\"2009-06 _度数\":\"\",\"2009-06 _单价\":\"\",\"2009-06 _金额\":\"\",\"2009-07 _度数\":\"1.00\",\"2009-07 _单价\":\"2.00\",\"2009-07 _金额\":\"2.0000\",\"2009-08 _度数\":\"4.00\",\"2009-08 _单价\":\"2.00\",\"2009-08 _金额\":\"8.0000\",\"合计_度数\":\"5.00\",\"合计_金额\":\"10.0000\"}]}"

主要是红色的部分

然后是js:

  Ext.onReady(function() {
            var conn = new Ext.data.Connection();
            conn.request({ url: 'FuelCompany.ashx', callback: function(options, success, response) {
                var a = response.responseText;
                var json = new Ext.util.JSON.decode(a);
                var jsonrows = "[[";
                var rows = {};
                var _temp = [];
                for (var item in json.columModle) {
                    if (item >= 0) {
                        var tempHeader = json.columModle[item].header
                        if (tempHeader.split('_').length > 1) {
                            _temp.push(tempHeader.split('_')[0]);
                            json.columModle[item].header = tempHeader.split('_')[1];
                        }
                        else
                            _temp.push("");
                    }
                }
                var i = 1;
                for (var item in _temp) {
                    if (item >= 0) {
                        if (_temp[item] != _temp[Number(item) + 1]) {
                            jsonrows += "{header:'" + _temp[item] + "',colspan:" + i.toString() + ",align:'center'},";
                            i = 1;
                        }
                        else
                            i++;
                    }
                }
                jsonrows = jsonrows.substring(0, jsonrows.length - 1);
                jsonrows += "]]";
                var cm = new Ext.grid.ColumnModel({
                    columns: json.columModle,
                    rows: new Ext.util.JSON.decode(jsonrows)
                });
                var ds = new Ext.data.JsonStore({
                    data: json.data,
                    fields: json.fieldsNames
                });
                var header = new Ext.ux.plugins.GroupHeaderGrid();
                var grid = new Ext.grid.EditorGridPanel({
                    height: 400,
                    region: 'center',
                    split: true,
                    border: false,
                    store: ds,
                    plugins: [header],
                    cm: cm,
                    renderTo: 'Div_CompanyProfile'
                });
            }
            });
        });

注意: Ext.ux.plugins.GroupHeaderGrid类源文件如下图所示

GroupHeaderPlugin.js文件源码:

Ext.namespace("Ext.ux.plugins");

Ext.ux.plugins.GroupHeaderGrid = function(config) {

 Ext.apply(this, config);

};

Ext.extend(Ext.ux.plugins.GroupHeaderGrid, Ext.util.Observable, {

 init: function(grid) {

  var v = grid.getView();

  v.beforeMethod('initTemplates', this.initTemplates);

  v.renderHeaders = this.renderHeaders.createDelegate(v, [v.renderHeaders]);

        v.afterMethod('onColumnWidthUpdated', this.updateGroupStyles);

        v.afterMethod('onAllColumnWidthsUpdated', this.updateGroupStyles);

  v.afterMethod('onColumnHiddenUpdated', this.updateGroupStyles);

  v.getHeaderCell = this.getHeaderCell;

  v.updateSortIcon = this.updateSortIcon;

  v.getGroupStyle = this.getGroupStyle;

 },

 initTemplates: function() {

  var ts = this.templates || {};

  if (!ts.gheader) {

   ts.gheader = new Ext.Template(

    '<table border="0" cellspacing="0" cellpadding="0" class="ux-grid-group-table" style="{tstyle}">',

    '<thead>{rows}{header}</thead>',

    '</table>'

   );

  }

  if (!ts.header) {

   ts.header = new Ext.Template(

    '<tr class="x-grid3-hd-row">{cells}</tr>'

   );

  }

  if (!ts.gcell) {

   ts.gcell = new Ext.Template(

    '<td class="x-grid3-hd {cls} x-grid3-td-{id}" style="{style}" rowspan="{rowspan}" colspan="{colspan}">',

    '<div {tooltip} class="x-grid3-hd-inner x-grid3-hd-{id}" unselectable="on" style="{istyle}">{value}</div>',

    '</td>'

   );

  }

  this.templates = ts;

 },

 renderHeaders: function(renderHeaders) {

  var ts = this.templates, rows = [], table = [];

  for (var i = 0; i < this.cm.rows.length; i++) {

   var r = this.cm.rows[i], cells = [], col = 0;

   for (var j = 0; j < r.length; j++) {

    var c = r[j];

    c.colspan = c.colspan || 1;

    c.rowspan = c.rowspan || 1;

    while (table[i] && table[i][col]) {

     col++;

    }

    c.col = col;

    for (var rs = i; rs < i + c.rowspan; rs++) {

     if (!table[rs]) {

      table[rs] = [];

     }

     for (var cs = col; cs < col + c.colspan; cs++) {

      table[rs][cs] = true;

     }

    }

    var gs = this.getGroupStyle(c);

    cells[j] = ts.gcell.apply({

     id: c.id || i + '-' + col,

     cls: c.header ? 'ux-grid-hd-group-cell' : 'ux-grid-hd-nogroup-cell',

     style: 'width:' + gs.width + ';' + (gs.hidden ? 'display:none;' : '') + (c.align ? 'text-align:' + c.align + ';' : ''),

     rowspan: c.rowspan,

     colspan: gs.colspan,

     tooltip: c.tooltip ? (Ext.QuickTips.isEnabled() ? 'ext:qtip' : 'title') + '="' + c.tooltip + '"' : '',

     value: c.header || '&#160;',

     istyle: c.align == 'right' ? 'padding-right:16px' : ''

    });

   }

   rows[i] = ts.header.apply({

    cells: cells.join('')

   });

  }

  return ts.gheader.apply({

   tstyle: 'width:' + this.getTotalWidth() + ';',

   rows: rows.join(''),

   header: renderHeaders.call(this)

  });

 },

 getGroupStyle: function(c) {

  var w = 0, h = true, cs = 0;

  for (var i = c.col; i < c.col + c.colspan; i++) {

   if (!this.cm.isHidden(i)) {

    var cw = this.cm.getColumnWidth(i);

    if(typeof cw == 'number'){

     w += cw;

    }

    h = false;

    cs++;

   }

  }

  return {

   width: (Ext.isBorderBox ? w : Math.max(w - this.borderWidth, 0)) + 'px',

   hidden: h,

   colspan: cs || 1

  }

 },

 updateGroupStyles: function(col) {

  var rows = this.mainHd.query('tr.x-grid3-hd-row');

  for (var i = 0; i < rows.length - 1; i++) {

   var cells = rows[i].childNodes;

   for (var j = 0; j < cells.length; j++) {

    var c = this.cm.rows[i][j];

    if ((typeof col != 'number') || (col >= c.col && col < c.col + c.colspan)) {

     var gs = this.getGroupStyle(c);

     cells[j].style.width = gs.width;

     cells[j].style.display = gs.hidden ? 'none' : '';

     cells[j].colSpan = gs.colspan;

    }

   }

  }

 },

 getHeaderCell : function(index){

  return this.mainHd.query('td.x-grid3-cell')[index];

 },

 updateSortIcon : function(col, dir){

  var sc = this.sortClasses;

  var hds = this.mainHd.select('td.x-grid3-cell').removeClass(sc);

  hds.item(col).addClass(sc[dir == "DESC" ? 1 : 0]);

 }

});



本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2011/10/10/2205245.html,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
消息中间件 运维 Java
【Log日志】logback.xml动态配置属性值(包括接入的第三方配置)
1如何动态配置Logback的存放路径 我们在开发过程中,会使用到logback.xml 配置来管理日志文件; 比如
|
人工智能 监控 Java
SpringBoot实战(十三):Spring Boot Admin 动态修改日志级别
SpringBoot实战(十三):Spring Boot Admin 动态修改日志级别
485 0
|
Java 数据库连接 网络性能优化
动态mapper日志问题
动态mapper日志问题
72 1
|
存储 JSON Prometheus
SpringBoot动态修改日志级别
SpringBoot动态修改日志级别
698 0
SpringBoot动态修改日志级别
|
存储 SQL JSON
无需重启应用,动态采集任意点位日志
借助日志治理的现有能力,我们能够在不重启应用的前提下,动态采集任意点位信息,同时由于日志治理在采集信息时会引入链路信息,在分析复杂调用问题时能够起到很好的效果。
无需重启应用,动态采集任意点位日志
|
存储 Java Spring
Spring动态自定义logback日志目录
Spring动态自定义logback日志目录 @Date 2018.10.18 问题场景 在业务开发中, 遇到一个场景. 日志目录需要根据不同的一个业务id存储.
2785 0
|
Arthas SQL 监控
动态修改LOGGER日志级别
大多数情况下,我们会在打印日志时定义日志的LOGGER级别,用来控制输出的信息范围。 一方面,过多的输出会影响查看日志的效率,另一方面,过少的日志让问题定位变得困难。 但当线上出现问题时,线上容器通常定义在info级别,发生一些疑难问题时,光靠info级别的日志很难定位问题。 一个典型的场景:在一些需要打印MySQL语句的场景,如果你正在使用MyBatis框架,由于MyBaits中SQL语句是DEBUG级别的信息,通常在线上容器就没法看到。
672 1
|
Python
Python 技术篇-在cmd命令提示行里模拟动态下载进度条实例演示,cmd清除日志、打印动态内容方法
Python 技术篇-在cmd命令提示行里模拟动态下载进度条实例演示,cmd清除日志、打印动态内容方法
543 0
|
存储 关系型数据库 MySQL
SLS数据加工——动态解析与分发日志实战
阿里云日志服务提供可托管、可扩展、高可用的数据加工服务。数据加工服务可用于数据的规整、富化、流转、脱敏和过滤。本文为读者带来了数据加工动态解析与分发的最佳实践。
840 0
|
监控 安全 Java
Spring Boot 1.5.x新特性:动态修改日志级别
Spring Boot 1.5.x新特性:动态修改日志级别
142 0