對FineU框架Grid多表頭合計行導出Excel的回顧

来源:http://www.cnblogs.com/ThreeStone007/archive/2016/03/04/5242575.html
-Advertisement-
Play Games

年前用FineUI開發遇到了這樣一個問題,Grid多表頭合計行不能導出,後面到官方示例找了一下,慶幸的是找到了多表頭的導出示例。然後當時為了省事,直接就複製粘貼完事,也沒有仔細的研究代碼。後來運行一看,多表頭的問題是解決了,合計行的問題還是沒有解決。 由於到時要趕流程這個問題就暫時的放在了那裡,時間


  年前用FineUI開發遇到了這樣一個問題,Grid多表頭合計行不能導出,後面到官方示例找了一下,慶幸的是找到了多表頭的導出示例。然後當時為了省事,直接就複製粘貼完事,也沒有仔細的研究代碼。後來運行一看,多表頭的問題是解決了,合計行的問題還是沒有解決。

  由於到時要趕流程這個問題就暫時的放在了那裡,時間長了也忘了這個問題,這個星期項目測試驗收才重新發現這個問題(還好客戶沒有發現,偷笑)。昨天不經意間調試了下,發現count只有16條數據,加上合計行應該有17條數據才對啊。仔細看了下代碼原來官方示例上的代碼根本就沒有寫導出合計行的代碼。

  找出問題就好辦了,整理下思路,首先要拿到合計行的數據保存為Json,然後拿到Grid所有列的ID,最後判斷合計行Json是否存在這個ID的節點,如果有就寫入數據沒有就寫入空

  下麵附上代碼

 1 sb.Append("<tr>");
 2             JObject summarty = grid.SummaryData;//獲取合計行數據
 3             if (summarty != null && summarty.ToString() != "")//判斷合計行數據是否為空
 4             {
 5                 foreach (GridColumn column in mht.Columns)//遍歷出列的id
 6                 {
 7                     if (summarty.Property(column.ColumnID.ToString()) == null || summarty.Property(column.ColumnID.ToString()).ToString() == "")//判斷合計行Json是否存在該節點
 8                     {
 9                         sb.AppendFormat("<td>{0}</td>", "");//如果沒有就為空
10                     }
11                     else
12                     {
13                         sb.AppendFormat("<td>{0}</td>", summarty[column.ColumnID.ToString()].ToString());//如果有就寫入數據
14                     }
15                 }
16             }
17             sb.Append("</tr>");

  至於多表頭的導出我就不解釋也不附上代碼了,直接引用三石大大的博客。http://www.cnblogs.com/sanshi/p/4104411.html

  

  第一次寫博客寫的不好,有問題的地方希望大家能夠指出,非常感謝!作為新人,在此給各位前輩問好,希望各位前輩多多指教。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.1 rsync伺服器端配置 1.1.1 查看伺服器端rsync版本 1.1.2 創建配置文件 預設安裝好rsync程式後,並不會自動創建rsync的主配置文件,需要手工來創建,其主配置文件為“/etc/rsyncd.conf”,創建該文件 並插入如下內容: 1 #Rsync server 2 #
  • 一.創建型模式 模式名稱 定 義 使用頻率 學習難度 簡單工廠模式 (Simple Factory Pattern) 定義一個工廠類,它可以根據參數的不同返回不同類的實例,被創建的實例通常都具有共同的父類。 ★★☆☆☆ ★★★☆☆ 工廠方法模式 (Factory Method Pattern) 定義
  • 單例模式三種寫法: 第一種最簡單,但沒有考慮線程安全,在多線程時可能會出問題 public class Singleton { private static Singleton _instance = null; private Singleton(){} public static Singlet
  • MVC中HtmlHelper用法大全參考 解析MVC中HtmlHelper控制項7個大類中各個控制項的主要使用方法(1) 2012-02-27 16:25 HtmlHelper類在命令System.Web.Mvc.Html之中,主要由7個靜態類組成,它們分別是FormExtensions類,InputE
  • 開篇 本篇文章主要是幫助剛開始接觸CrystalReport報表的新手提供一個循序漸進的教程。該教程主要分為三個部分1)CrystalReport的基本使用方法;2)使用CrystalReport對數據進行分組求和;3)CrystalReport如何使用自定義的數據源(如記憶體中的DataTable表
  • 我們以做一個計算器為例,給大家介紹簡單工廠的應用: 效果: 這裡我們使用 繼承 ,虛方法, 簡單工廠的設計模式來完成 首先,我們除了搭好窗體外,我們應該把我們的一些類準備好: 1.計算的父類Calculation using System; using System.Collections.Gene
  • 最近看見一個騎士飛行棋的小游戲代碼,感覺這個代碼中將大多數C#的基礎知識都運用到了,是一個新手檢驗學習成果的有效方法,特此將這個代碼整理一遍。這是一個控制台程式。這是代碼下載地址,代碼中的註釋非常詳細介紹了每段代碼的作用: http://files.cnblogs.com/files/xiaohua
  • 上一次介紹的了Rookey.Frame v1.0快速開發平臺的整體功能,接下來會對各個功能點進行解析說明,今天給大家介紹下系統登錄功能。 用戶登錄 系統中基本上所有功能頁面都是從後臺代碼拼接後返回的,登錄頁面也不例外,請看下圖: 接下來看下後臺登錄的HTML: /// <summary> /// 獲
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...