zoukankan      html  css  js  c++  java
  • (较难)行扩展列

    <ext:Grid ID="Grid1" runat="server" EnableColumnLines="true" Title="委托单明细" ShowBorder="true"

    DataKeyNames="AID,FlowType,FlowNode,SnID,ClientAID" BoxConfigAlign="Stretch" BoxFlex="1" EnableTextSelection="true"
    OnSort="Grid1_Sort" AllowSorting="true" OnRowCommand="Grid1_RowCommand" SortField="CreateTime" SortDirection="DESC" EnableMultiSelect="true"DataIDField="AID"

    AllowPaging="true" PageSize="20" IsDatabasePaging="true" ClearSelectedRowsAfterPaging="false" OnPageIndexChange="Grid1_PageIndexChange" >

    <Columns>
    <ext:RowNumberField EnablePagingNumber="true" Width="40" HeaderText="序号"/>
    <ext:BoundField runat="server" HtmlEncode="false" Width="100" SortField="FlowName" DataField="FlowName" HeaderText="当前状态" />
    <ext:TemplateField ColumnID="expander" RenderAsRowExpander="true" HeaderText="明细">

    <ItemTemplate>
    </ItemTemplate>
    </ext:TemplateField>

     </Columns>

    </ext:Grid>

    F.ready(function () {
    var grid1Cmp = F(grid1);

    // 展开行扩展列事件
    grid1Cmp.view.on('expandbody', function (rowNode, record, expandRow) {

    var tplEl = Ext.get(expandRow).query('.f-grid-tpl')[0];
    if (!Ext.String.trim(tplEl.innerHTML)) {

    var store = Ext.create('Ext.data.Store', {
    fields: ['GYKSnID', 'YSJLSnID', 'ReportSnID', 'GID', 'YID', 'RID'],
    proxy: {
    type: 'ajax',
    url: './SqlDataJsonHandler.ashx?AID=' + record.getId(),
    reader: {
    type: 'json',
    root: 'data',
    totalProperty: 'total'
    }
    },
    autoLoad: true,
    listeners: {
    load: function () {
    rowExpandersDoLayout();
    }
    }
    });

    var store = Ext.create('Ext.data.Store', {
    fields: ['GYKSnID', 'YSJLSnID', 'ReportSnID', 'GID', 'YID', 'RID'],
    proxy: {
    type: 'ajax',
    url: './SqlDataJsonHandler.ashx?AID=' + record.getId(),
    reader: {
    type: 'json',
    root: 'data',
    totalProperty: 'total'
    }
    },
    autoLoad: true,
    listeners: {
    load: function () {
    rowExpandersDoLayout();
    }
    }
    });


    Ext.create('Ext.grid.Panel', {
    renderTo: tplEl,
    header: false,
    border: true,
    draggable: false,
    enableDragDrop: false,
    enableColumnResize: true,
    cls: 'gridinrowexpander',
    store: store,
    columns: [
    {
    text: '工艺卡', dataIndex: 'GYKSnID', sortable: false, menuDisabled: true, 300, renderer: function (value, meta, record) {
    var link = "<span style='margin-right:10px'><a href=javascript:GetGYKUrl(";
    link = link + record.get('GID') + ")>" + record.get('GYKSnID') + "</a></span>";
    return link;
    }

    }, {
    text: '原始记录', dataIndex: 'YSJLSnID', sortable: false, menuDisabled: true, 300, renderer: function (value, meta, record) {
    return "<span style='margin-right:10px'><a href='#''>" + record.get('YSJLSnID') + "</a></span>";
    }
    }, {
    text: '报告', dataIndex: 'ReportSnID', sortable: false, menuDisabled: true, 300, renderer: function (value, meta, record) {
    return "<span style='margin-right:10px'><a href='#''>" + record.get('ReportSnID') + "</a></span>";
    }
    }]
    });
    } else {
    rowExpandersDoLayout();
    }
    });

    // 折叠行扩展列事件
    grid1Cmp.view.on('collapsebody', function (rowNode, record, expandRow) {
    rowExpandersDoLayout();
    });

    });


    // 重新布局表格和行扩展列中的表格(解决出现纵向滚动条时的布局问题)
    function rowExpandersDoLayout() {
    var grid1Cmp = F(grid1);

    grid1Cmp.doLayout();

    $('.x-grid-item:not(.x-grid-item-collapsed) .gridinrowexpander').each(function () {
    var gridInside = F($(this).attr('id'));
    gridInside.doLayout();
    });
    };


    function DomUrl(value) {
    return "<a href=>" + value + "</a>";
    };


    function GetGYKUrl(AID) {

    F('<%= Window1.ClientID %>').f_show("BGXT_02GYK_ModifyFlow.aspx?AID=" + AID);

    };

    function GetYSJLUrl(AID) {

    F('<%= Window1.ClientID %>').f_show("BGXT_02GYK_ModifyFlow.aspx?AID=" + AID);

    };

    function GetReportUrl(AID) {

    F('<%= Window1.ClientID %>').f_show("BGXT_02GYK_ModifyFlow.aspx?AID=" + AID);

    };

    <%@ WebHandler Language="C#" Class="SqlDataJsonHandler" %>

    using System;
    using System.Web;
    using Govaze;
    using System.Data;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Runtime.Serialization.Json;
    using System.Text;
    using System.Web;
    using System.Web.Script.Serialization;
    using System.Xml.Linq;

    public class SqlDataJsonHandler : IHttpHandler {

    public void ProcessRequest(HttpContext context)
    {
      context.Response.ContentType = "text/plain";

      string AID = context.Request["AID"] != null ? context.Request["AID"].Trim().ToString().Trim().ToString() : null;
      string outPutMsg = string.Empty;
      outPutMsg = LoadData(AID);

      context.Response.Write(outPutMsg);//将处理后的Json数据传出
      context.Response.End();



    }

    private string LoadData(string AID)
    {
      XElement xl = new XElement("root", new XElement("Type", "Documents")
      , new XElement("AID", AID));

      DataTable dt = Govaze.SQLServerDAL.Factory.getDataXmlDAL().ProcDataTable(xl.ToString(), "DataXmlApplication");
      string ss = Govaze.SQLServerDAL.Factory.getDataXmlDAL().ToJson(dt);

      datatable转换为json

      return ("{data:" + ss + "}");
    }

    private void Exec(string TypeString, string sp)
    {

      Govaze.SQLServerDAL.Factory.getDataXmlDAL().ExecProc(TypeString, sp);

    }



    public bool IsReusable
    {
      get
      {
        return false;
      }
    }
    /// <summary>
    /// Json反序列化操作
    /// 注意:根据前面提供的数据需要小小的字符串处理
    /// </summary>
    /// <param name="json"></param>
    /// <returns></returns>
    private List<Documents> JsonDeserialize(string json)
    {

      List<Documents> docu = new List<Documents>();
      if (!string.IsNullOrEmpty(json))
      {
        json = json.Replace("'", """);//字符串处理
        DataContractJsonSerializer jsonDeserializer = new DataContractJsonSerializer(typeof(List<Documents>));
        MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(json));
        docu = (List<Documents>)jsonDeserializer.ReadObject(ms);
        }
        return docu;
    }

    /// <summary>
    /// 委托单子表数据
    /// </summary>
    public class Documents
    {

      public string GYKSnID;
      public int GID;
      public string YSJLSnID;
      public int YID;
      public string ReportSnID;
      public int RID;


    }




    }

  • 相关阅读:
    《基于UML的电子病案管理系统的设计》文献阅读随笔
    《暗时间》读书笔记
    《基于物联网技术的无纸化电子病案管理系统设计与应用》文献阅读随笔
    文献随笔目录
    C语言程序设计第一次作业
    python基础 day24 面向对象——封装
    python基础 day23 面向对象相关
    python基础 day22 面向对象初识
    python基础 day21 re模块及shutil、logging模块
    python基础 day20 正则表达式及re模块及装饰器
  • 原文地址:https://www.cnblogs.com/sanshengshitouhua/p/14353296.html
Copyright © 2011-2022 走看看