zoukankan      html  css  js  c++  java
  • Extjs 3.2.1 GridPanel 分页(数据源为aspx返回的xml格式数据流)

    刚开始学习Extjs,百度+股沟了很久,看了很多例子,发现还是官方的API最管用,其实重要的还是在理解其原理上

    比如分页,是按照传给aspx页面的params: { start: 0, limit: 26}来进行取值的,其实分页还是在后台自己处理的

    另外增加了网上找的导出数据到Excel以便打印的功能

    废话少说,代码展示一切:

    主页面:

    Default.aspx
    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
    <title></title>

    <%--ExtJS库--%>
    <link rel="stylesheet" type="text/css" href="ExtJS/resources/css/ext-all.css" />
    <script type="text/javascript" src="ExtJS/adapter/ext/ext-base.js"></script>
    <script type="text/javascript" src="ExtJS/ext-all.js"></script>

    <%--数据处理JS--%>
    <script type="text/javascript" src="GetData.js" charset="gb2312"></script>

    </head>
    <body>

    <div id="myGrid">

    </div>

    </body>
    </html>

    取值页面后台Data.aspx.cs 

    Data.aspx.cs
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;

    public partial class Data : System.Web.UI.Page
    {
    protected void Page_Load(object sender, EventArgs e)
    {
    int start = Int32.Parse(Request["start"]);
    int limit = Int32.Parse(Request["limit"]);

    List
    <string> datalist = new List<string>();
    datalist
    = GetData();
    datalist.TrimExcess();

    int end = start + limit;//得到数据总量

    string datastr = "<records><totalRecords>"+ datalist.Count.ToString() +"</totalRecords>";

    //该判断用于最后一页数据小于每页行数的情况,更新要返回的limit
    if (end > datalist.Count)//如果请求数据总量大于实际数据总量
    {
    limit
    = datalist.Count - start;//修改将要取值的条数
    }

    for (int i = 0; i < limit; i++)
    {
    datastr
    += datalist.GetRange(start, limit)[i].ToString();//取值
    }

    datastr
    += "</records>";

    Response.ContentType
    = "text/xml";
    Response.Write(datastr);
    }

    private List<string> GetData()
    {
    List
    <string> datalist = new List<string>();
    //string data = "<records><totalRecords>100</totalRecords>";
    string data = "";
    for (int i = 1; i <= 100; i++)
    {
    data
    = "<record>";
    data
    += "<id>" + i.ToString() + "</id>";
    data
    += "<name>" + "" + i.ToString() + "" + "</name>";
    data
    += "<time>" + DateTime.Now.ToLongTimeString() + "</time>";
    data
    += "</record>";

    datalist.Add(data);
    data
    = "";
    }

    return datalist;
    }
    }

    核心JS文件 

    GetData.js

    var myInfo = Ext.data.Record.create([
    {name:
    'name', mapping: 'name'},
    {name:
    'time',mapping:'time'}
    ]);

    var myReader = new Ext.data.XmlReader({
    totalProperty:
    'totalRecords',
    record:
    'record',
    idProperty:
    'id'
    },myInfo);

    var ds = new Ext.data.Store({
    proxy:
    new Ext.data.HttpProxy({
    url:
    'Data.aspx'
    }),
    reader:myReader
    });

    //重载RowNumberer,使每页的行编号自动增加
    Ext.grid.RowNumberer = Ext.extend(Ext.grid.RowNumberer, {
    renderer:
    function (value, cellmeta, record, rowIndex, columnIndex, store) {
    return store.lastOptions.params.start + rowIndex + 1;
    }
    });

    var rownum = new Ext.grid.RowNumberer();
    rownum.width
    = 40;

    var cm = new Ext.grid.ColumnModel([
    rownum,
    { header:
    '姓名', dataIndex: 'name' },
    { header:
    '时间', dataIndex: 'time' }
    ]);

    Ext.onReady(
    function () {
    Ext.BLANK_IMAGE_URL
    = 's.gif';
    var grid = new Ext.grid.GridPanel({
    renderTo:
    'myGrid',
    loadMask: { msg:
    '数据请求中,请稍后...' },
    cm: cm,
    store: ds,
    stripeRows:
    true, //隔行颜色不同
    title: '事件记录报表',
    tbar:
    new Ext.Toolbar({
    600,
    items: [
    '查询时间',
    '-',
    {
    text:
    '打印',
    cls:
    'x-btn-text',
    handler:
    function () {
    downloadViewData(grid);
    }
    }
    ]
    }),
    600,
    height:
    500,
    bbar:
    new Ext.PagingToolbar({
    pageSize:
    26,
    store: ds,
    displayInfo:
    true,
    beforePageText:
    '',
    afterPageText:
    '/{0}页',
    firstText:
    '首页',
    prevText:
    '上一页',
    nextText:
    '下一页',
    lastText:
    '尾页',
    displayMsg:
    '显示 第 {0} 条 到 第 {1} 条 记录,共 {2} 条记录',
    emptyMsg:
    '无记录'
    })
    });
    ds.load({
    params: { start:
    0, limit: 26 }
    });

    function downloadViewData(grid) {
    try {
    var xls = new ActiveXObject('Excel.Application');
    }
    catch (e) {
    alert(
    '未安装Excel软件或者当前浏览器禁止执行控件');
    return '';
    }

    var cm = grid.getColumnModel();
    var colCount = cm.getColumnCount();

    xls.visible
    = true;
    var xlBook = xls.Workbooks.Add;
    var xlSheet = xlBook.Worksheets(1);

    var temp_obj = [];

    //获取列标
    for (i = 1; i < colCount; i++) {
    if (cm.isHidden(i) == true) {
    //隐藏列不打印
    } else {
    temp_obj.push(i);
    }
    }

    //获取列标题值
    for (i = 1; i <= temp_obj.length; i++) {
    xlSheet.Cells(
    1, i).Value = cm.getColumnHeader(temp_obj[i - 1]);
    }

    var store = grid.getStore();
    var recordCount = store.getCount();
    var view = grid.getView();

    //获取数据值
    for (i = 1; i <= recordCount; i++) {
    for (j = 1; j <= temp_obj.length; j++) {
    xlSheet.Cells(i
    + 1, j).Value = view.getCell(i - 1, temp_obj[j - 1]).innerText;
    }
    }

    xlSheet.Columns.AutoFit;
    xls.ActiveWindow.Zoom
    = 75; //设置Excel单元格的大小
    xls.UserControl = true;
    xls
    = null;
    xlBook
    = null;
    xlSheet
    = null;
    }
    });
  • 相关阅读:
    一个网络狂人的财富轨迹
    婚姻的精髓
    软件史上最伟大的十大程序员
    由瓜子理论引出的人力资源管理启示
    感情裂缝的"维修工" 在生活抛锚的地方起航
    寻找更新过的数据
    asp.net mvc中TempData和ViewData的区别
    SQL Server Backup
    VS字符串时间转换用法
    SQL Server 根据动态条件insert,update语句
  • 原文地址:https://www.cnblogs.com/jiewei915/p/1804372.html
Copyright © 2011-2022 走看看