c#依參數自動生成控制項

来源:https://www.cnblogs.com/atomy/archive/2018/08/17/9491424.html
-Advertisement-
Play Games

很多系統都帶有自定義報表的功能,而此功能都需依參數自動生成控制項,舉例如下: 如上圖,一條查詢語句當中,包含了3個參數,其中兩個是日期型(使用:DATE!進行標識),一個是字元型(使用:進行標識),要生成的效果圖如下所示: 代碼如下: 好了,分享就到這裡,希望對大家有一些幫助。 ...


  很多系統都帶有自定義報表的功能,而此功能都需依參數自動生成控制項,舉例如下:

  

  如上圖,一條查詢語句當中,包含了3個參數,其中兩個是日期型(使用:DATE!進行標識),一個是字元型(使用:進行標識),要生成的效果圖如下所示:

  

  代碼如下:

private void FrmDefine_MyEventClose(string strID, string strName, string strSql)
{
    //值傳遞
    ReturnID = strID;
    ReturnName = strName;
    ReturnSql = strSql;
    //空格清除
    while (ReturnSql.IndexOf(": ") != -1)
    {
        ReturnSql = ReturnSql.Replace(": ", ":");
    }
    while (ReturnSql.IndexOf(":DATE! ") != -1)
    {
        ReturnSql = ReturnSql.Replace(":DATE! ", ":DATE!");
    }
    //產生標題
    rtxtName.Text = "[" + strID + "]" + strName;
    rtxtName.SelectionAlignment = System.Windows.Forms.HorizontalAlignment.Center;
    //清除控制項
    splitContainer2.Panel1.Controls.Clear();
    //添加控制項
    if (strSql.IndexOf(":") != -1)
    {
        int ParamIndex = 100;   //參數序號,從100往前倒數。
        ParamSql = string.Empty;
        List<string> list = new List<string>(ReturnSql.Split(' '));
        for (int i = list.Count - 1; i > -1; i--)
        {
            if (list[i].IndexOf(":") == -1)
            {
                ParamSql = list[i] + " " + ParamSql;
                list.RemoveAt(i);
            }
            else
            {
                if (list[i].IndexOf(":DATE!") != -1)
                {
                    if (list[i].IndexOf(":DATE!") == 0)
                    {
                        ParamSql = "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                    else
                    {
                        ParamSql = list[i].Substring(0, list[i].IndexOf(":DATE!")) + "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                }
                else
                {
                    if (list[i].IndexOf(":") == 0)
                    {
                        ParamSql = "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                    else
                    {
                        ParamSql = list[i].Substring(0, list[i].IndexOf(":")) + "Params[" + ParamIndex.ToString() + "] " + ParamSql;
                        ParamIndex--;
                    }
                }
            }
        }
        //添加控制項
        if (list.Count > 0)
        {
            //坐標初始化
            Point point = new Point(6, 6);
            //控制項行數
            int intRow = 0;
            //以6個參數為一行,初始化控制項面板的高度。
            splitContainer2.SplitterDistance = 25 * Convert.ToInt32(Math.Ceiling(list.Count / 6.0));
            //控制項添加
            ParamIndex = 100 - list.Count + 1;
            for (int i = 0; i < list.Count; i++)
            {
                string strLabelText = string.Empty;
                if (i % 6 == 0 && i != 0)
                {
                    intRow++;
                    point.X = 6;
                    point.Y = 6 + 25 * intRow;
                }
                //日期及文本
                if (list[i].IndexOf(":DATE!") != -1)
                {
                    //Label
                    strLabelText = list[i].Substring(list[i].IndexOf(":DATE!") + 6, list[i].Length - list[i].IndexOf(":DATE!") - 6);
                    Label label = new Label();
                    label.Name = "Label" + i.ToString();
                    label.Text = strLabelText;
                    label.AutoSize = true;
                    label.Location = point;
                    splitContainer2.Panel1.Controls.Add(label);
                    //DateTimePicker
                    DateTimePicker dateTimePicker = new DateTimePicker();
                    dateTimePicker.Name = "Params[" + ParamIndex.ToString() + "]";
                    dateTimePicker.Format = DateTimePickerFormat.Custom;
                    dateTimePicker.CustomFormat = "yyyy-MM-dd";
                    dateTimePicker.Width = 100;
                    point.X = point.X + label.Width + 4;
                    point.Y = label.Location.Y - 4;
                    dateTimePicker.Location = point;
                    splitContainer2.Panel1.Controls.Add(dateTimePicker);
                    //坐標初始化
                    point.X += 112;
                    point.Y = label.Location.Y;
                }
                else
                {
                    //Label
                    strLabelText = list[i].Substring(list[i].IndexOf(":") + 1, list[i].Length - list[i].IndexOf(":") - 1);
                    Label label = new Label();
                    label.Name = "Label" + i.ToString();
                    label.Text = strLabelText;
                    label.AutoSize = true;
                    label.Location = point;
                    splitContainer2.Panel1.Controls.Add(label);
                    //TextBox
                    TextBox textBox = new TextBox();
                    textBox.Name = "Params[" + ParamIndex.ToString() + "]";
                    textBox.Text = string.Empty;
                    textBox.Width = 100;
                    point.X = point.X + label.Width + 4;
                    point.Y = label.Location.Y - 4;
                    textBox.Location = point;
                    splitContainer2.Panel1.Controls.Add(textBox);
                    //坐標初始化
                    point.X += 112;
                    point.Y = label.Location.Y;
                }
                //參數序號賦值
                ParamIndex++;
            }
        }
    }
    //數據源初始化
    dataGridView1.DataSource = null;
}

  好了,分享就到這裡,希望對大家有一些幫助。


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

-Advertisement-
Play Games
更多相關文章
  • 問題:考慮屏幕大小,一般都是會在表單問卷的頁面使用ScrollViewer。問卷中問題漏填漏選時,在提交時校驗不過,需要滾動跳轉至漏填漏選項。 頁面如下: 每個選項使用StackPanel,並對覆選框和單選的勾選事件進行答案記錄,使用全局變數記錄 將所有選項使用StackPanel指定垂直樣式,思路 ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:https://www.bitadmincore.com 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 什麼是.NET Core Globa ...
  • 最近我跟一個漏洞還有一群阿三幹起來了…… 背景: 我的客戶是一個世界知名的藥企,最近這個客戶上臺了一位阿三管理者,這個貨上線第一個事兒就是要把現有的軟體供應商重新洗牌一遍。由於我們的客戶關係維護的非常好,直接對口人提前透露給我們這個管理者就是想讓一個阿三公司壟斷他們的軟體供應,並且表示了非常鄙視。我 ...
  • 索引 NET Core應用框架之BitAdminCore框架應用篇系列 框架演示:http://bit.bitdao.cn 框架源碼:https://github.com/chenyinxin/cookiecutter-bitadmin-core 20180817更新內容 1、考慮到大部分項目不需要 ...
  • 本節對委托、事件做以總結。 一、委托: 1、概念:先來說明變數和函數的概念,變數,以某個地址為起點的一段記憶體中所存儲的值,函數,以某個地址為起點的一段記憶體中存儲的機器語言指令。有了這2個概念以後,我們來看c++中的函數指針,函數指針就是指向這個函數的地址,函數指針所指向的類型就是函數在記憶體中的大小, ...
  • 通過以下步驟,可以簡單瞭解到如何下載我們Smobiler Designer(設計器)、Client(客戶端),以及如何通過設計器進行開發和調試移動應用,併在服務端部署、Cloud打包、訪問自己所開發的移動應用。 ...
  • 對谷歌瓦片地圖進行糾偏,有兩種方法:一是對拼接大圖進行糾偏,然後重新切片;二是直接對瓦片圖進行糾偏。這裡我用的是第二種方法,即直接對瓦片地圖進行糾偏。 App.config配置: <appSettings> <add key="inputPath" value="D:\_臨時文件\GISMap\18 ...
  • 簡介 ASP.NET Boilerplate提供了構建模塊的基礎結構,並將它們組合在一起以創建應用程式。 模塊可以依賴於另一個模塊。 通常,一個程式集被視為一個模塊。 如果創建具有多個程式集的應用程式,建議您為每個程式集創建一個模塊定義。 模塊系統目前專註於服務端,而不是客戶端。 模塊定義 定義一個 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...