sample-grid.js
上传用户:shuoshiled
上传日期:2018-01-28
资源大小:10124k
文件大小:4k
源码类别:

中间件编程

开发平台:

JavaScript

  1. /*!  * Ext JS Library 3.0.0  * Copyright(c) 2006-2009 Ext JS, LLC  * licensing@extjs.com  * http://www.extjs.com/license  */ SampleGrid = function(limitColumns){
  2.     function italic(value){
  3.         return '<i>' + value + '</i>';
  4.     }
  5.     function change(val){
  6.         if(val > 0){
  7.             return '<span style="color:green;">' + val + '</span>';
  8.         }else if(val < 0){
  9.             return '<span style="color:red;">' + val + '</span>';
  10.         }
  11.         return val;
  12.     }
  13.     function pctChange(val){
  14.         if(val > 0){
  15.             return '<span style="color:green;">' + val + '%</span>';
  16.         }else if(val < 0){
  17.             return '<span style="color:red;">' + val + '%</span>';
  18.         }
  19.         return val;
  20.     }
  21.     var columns = [
  22.         {id:'company',header: "Company", width: 160, sortable: true, dataIndex: 'company'},
  23.         {header: "Price", width: 75, sortable: true, renderer: Ext.util.Format.usMoney, dataIndex: 'price'},
  24.         {header: "Change", width: 75, sortable: true, renderer: change, dataIndex: 'change'},
  25.         {header: "% Change", width: 75, sortable: true, renderer: pctChange, dataIndex: 'pctChange'},
  26.         {header: "Last Updated", width: 85, sortable: true, renderer: Ext.util.Format.dateRenderer('m/d/Y'), dataIndex: 'lastChange'}
  27.     ];
  28.     // allow samples to limit columns
  29.     if(limitColumns){
  30.         var cs = [];
  31.         for(var i = 0, len = limitColumns.length; i < len; i++){
  32.             cs.push(columns[limitColumns[i]]);
  33.         }
  34.         columns = cs;
  35.     }
  36.     SampleGrid.superclass.constructor.call(this, {
  37.         store: new Ext.data.Store({
  38.             reader: new Ext.data.ArrayReader({}, [
  39.                    {name: 'company'},
  40.                    {name: 'price', type: 'float'},
  41.                    {name: 'change', type: 'float'},
  42.                    {name: 'pctChange', type: 'float'},
  43.                    {name: 'lastChange', type: 'date', dateFormat: 'n/j h:ia'}
  44.               ]),
  45.             data: [
  46.                 ['3m Co',71.72,0.02,0.03,'9/1 12:00am'],
  47.                 ['Alcoa Inc',29.01,0.42,1.47,'9/1 12:00am'],
  48.                 ['Altria Group Inc',83.81,0.28,0.34,'9/1 12:00am'],
  49.                 ['American Express Company',52.55,0.01,0.02,'9/1 12:00am'],
  50.                 ['American International Group, Inc.',64.13,0.31,0.49,'9/1 12:00am'],
  51.                 ['AT&T Inc.',31.61,-0.48,-1.54,'9/1 12:00am'],
  52.                 ['Boeing Co.',75.43,0.53,0.71,'9/1 12:00am'],
  53.                 ['Caterpillar Inc.',67.27,0.92,1.39,'9/1 12:00am'],
  54.                 ['Citigroup, Inc.',49.37,0.02,0.04,'9/1 12:00am'],
  55.                 ['E.I. du Pont de Nemours and Company',40.48,0.51,1.28,'9/1 12:00am'],
  56.                 ['Exxon Mobil Corp',68.1,-0.43,-0.64,'9/1 12:00am'],
  57.                 ['General Electric Company',34.14,-0.08,-0.23,'9/1 12:00am'],
  58.                 ['General Motors Corporation',30.27,1.09,3.74,'9/1 12:00am'],
  59.                 ['Hewlett-Packard Co.',36.53,-0.03,-0.08,'9/1 12:00am'],
  60.                 ['Honeywell Intl Inc',38.77,0.05,0.13,'9/1 12:00am'],
  61.                 ['Intel Corporation',19.88,0.31,1.58,'9/1 12:00am'],
  62.                 ['International Business Machines',81.41,0.44,0.54,'9/1 12:00am'],
  63.                 ['Johnson & Johnson',64.72,0.06,0.09,'9/1 12:00am'],
  64.                 ['JP Morgan & Chase & Co',45.73,0.07,0.15,'9/1 12:00am'],
  65.                 ['McDonald's Corporation',36.76,0.86,2.40,'9/1 12:00am'],
  66.                 ['Merck & Co., Inc.',40.96,0.41,1.01,'9/1 12:00am'],
  67.                 ['Microsoft Corporation',25.84,0.14,0.54,'9/1 12:00am'],
  68.                 ['Pfizer Inc',27.96,0.4,1.45,'9/1 12:00am'],
  69.                 ['The Coca-Cola Company',45.07,0.26,0.58,'9/1 12:00am'],
  70.                 ['The Home Depot, Inc.',34.64,0.35,1.02,'9/1 12:00am'],
  71.                 ['The Procter & Gamble Company',61.91,0.01,0.02,'9/1 12:00am'],
  72.                 ['United Technologies Corporation',63.26,0.55,0.88,'9/1 12:00am'],
  73.                 ['Verizon Communications',35.57,0.39,1.11,'9/1 12:00am'],
  74.                 ['Wal-Mart Stores, Inc.',45.45,0.73,1.63,'9/1 12:00am']
  75.             ]
  76.         }),
  77.         columns: columns,
  78.         autoExpandColumn: 'company',
  79.         height:250,
  80.         width:600
  81.     });
  82. }
  83. Ext.extend(SampleGrid, Ext.grid.GridPanel);