C# Web控件与数据感应之数据返写

目录

关于数据返写

准备视图

范例运行环境

ControlInducingFieldName 方法

设计与实现

如何根据 ID 查找控件

FindControlEx 方法

调用示例 

小结


关于数据返写

数据感应也即数据捆绑,是一种动态的,Web控件与数据源之间的交互,数据返写 ,是指将查询出来的数据,通过可显示数据的UI控件进行数据输出,如查询详情页,见下图:

如图其中放置了一些标签(Label)控件用于查询输出,比如单位名称、项目名称、被测评人、总得分、手机号或账户等信息。

本文将介绍如何中通过 C# 实现查询并返写数据到服务器UI控件上。

准备视图

我们在 MS SQL Server 创建视图 v_es_project_persons(考试人员详情视图),其结构如下表:

序号字段名类型说明
1ciduniqueidentifier项目唯一标识
2wxmpciduniqueidentifier人员唯一标识
3ProjectNamenvarchar项目名称
4pubstatenvarchar项目发布状态
5personsint项目允许考试人数上限
6namenvarchar姓名
7mobilenvarchar手机
8scorenumeric考试成绩

执行定位项目及人员的查询SQL语句,如下:

select wxmpcid,ProjectName,pubstate,persons,name,mobile,score 
from v_es_project_persons 
where cid='960105b0-42b6-413a-a87a-f5fa338b2f2c' and wxmpcid='21f4c424-a1df-4161-be1b-ce441e058be6'

最后我们将数据填充到 DataReader ,并生成对应的二维数组。

范例运行环境

操作系统: Windows Server 2019 DataCenter

数据库:Microsoft SQL Server 2016

.net版本: .netFramework4.0 或以上

开发工具:VS2019  C#

ControlInducingFieldName 方法

设计与实现

ControlInducingFieldName 方法主要是通过 object[,] 二维对象数组数据源进行提取并根据字段名与控件ID进行匹配,查找匹配成功则根据控件的数据呈现属性进行赋值,其参数设置见下表:

序号参数名类型说明
1HasTitlebool数据集是否包含列名,如果包含则数据输出从第2行开始
2VerticalQueryModebool垂直字典查询模式,数据集第1列为要查找的ID值,第2列为要输出的值

GetReaderData 方法可以访问数据库数据表进行查询结果的提取,并转化为 object[,] 二维数组,具体实现请参考我的文章:《C# Web控件与数据感应之 填充 HtmlTable》中的GetReaderData 方法实现代码。

ControlInducingFieldName 方法实现代码如下:

ArrayList paras=new ArrayList();
string refSql="";
System.Data.CommandType ct=System.Data.CommandType.Text;public void ControlInducingFieldName(bool HasTitle,bool VerticalQueryMode)
{object[,] ReaderData = GetReaderData("SqlServer","您的连接串",refSql,paras,HasTitle,ct);if (ReaderData == null) return;for (int i =(HasTitle==true?1:0); i < ReaderData.GetLength(0); i++){for (int j = (VerticalQueryMode==false?0:1); j < ReaderData.GetLength(1); j++){string _fieldname = "";Control ctl = new Control();if (VerticalQueryMode == false){_fieldname = ReaderData[0, j].ToString();ctl=FindControlEx(_fieldname + (i == 1 ? "" : i.ToString()));}else{_fieldname = ReaderData[i, 0].ToString();ctl = FindControlEx(_fieldname);}if (ctl != null ){if (ctl.GetType() == typeof(Label)){((Label)ctl).Text = ReaderData[i, j].ToString();}else if (ctl.GetType() == typeof(Literal)){((Literal)ctl).Text = ReaderData[i, j].ToString();}else if (ctl.GetType() == typeof(TextBox)){((TextBox)ctl).Text =  ReaderData[i, j].ToString();}else if (ctl.GetType() == typeof(DropDownList)){((DropDownList)ctl).SelectedValue = ReaderData[i, j].ToString();}else if (ctl.GetType() == typeof(HyperLink)){((HyperLink)ctl).NavigateUrl = ReaderData[i, j].ToString();}else if (ctl.GetType() == typeof(HtmlLink)){((HtmlLink)ctl).Href = ReaderData[i, j].ToString();}else if (ctl.GetType().ToString().IndexOf("System.Web.UI.HtmlControls") == 0){string[] styles = ReaderData[i, j].ToString().Split(';');for (int s = 0; s < styles.Length; s++){string[] style = styles[s].Split(':');if (style.Length > 1){string _key = style[0];string _value = style[1];((HtmlControl)ctl).Style[_key] = _value;if (_key.ToLower().Trim() == "visible" && _value.ToLower().Trim() == "false"){((HtmlControl)ctl).Visible = false;}else if (_key.ToLower().Trim() == "visible" && _value.ToLower().Trim() == "true"){((HtmlControl)ctl).Visible = true;}}}}//ctl set}//if ctl not null }}
}//control inducing fieldname

如何根据 ID 查找控件

FindControlEx 实现了对 FindControl 方法的扩充,如果查找不成功可试图查找是否有母版页,如果存在,则根据母版页模式继续查找。

FindControlEx 方法

FindControlEx 通过传递要查找的服务器容器控件和ID参数,以返回查找到的控件,代码如下:

public Control  FindControlEx(Control FindPage,string ID)
{Control ctl=FindPage.FindControl(ID);if (ctl == null && FindPage.Page.Master != null){ctl=FindPage.Page.Master.FindControl(ID);}return ctl ;
}

调用示例 

客户端 UI 设计代码如下,控件的ID与字段名输出保持一致即可:

<h2><asp:Label ID="fnamelabel" runat="server" Text="查看个人详情"></asp:Label>
</h2><div style="display: flex;"><div class="query-box"><label>项目名称:</label><asp:Label ID="ProjectName" Text="" Font-Bold="true" runat="server" />(人数上限:<asp:LabelID="persons" Text="" runat="server" />人)</div></div><div style="display: flex;"><div class="query-box"><label>被测评人:</label><asp:Label ID="name" Text="" Font-Bold="true" runat="server" /></div><div class="query-box" style=" margin-left :10px;"><label>总得分:</label><asp:Label ID="score" Text="" Font-Bold="true" runat="server" /></div></div><div style="display: flex;"><div class="query-box"><label>手机号或账户:</label><asp:Label ID="mobile" Text="" Font-Bold="true" runat="server" /></div></div>

服务端示例代码如下(假设传递项目唯一标识和人员唯一标识参数):

ArrayList paras = new ArrayList();
string refSQL = "select wxmpcid,ProjectName,pubstate,persons,name,mobile,score 
from v_es_project_persons where cid=@cid and wxmpcid=@wxmpcid";paras.Clear();
paras.Add(new SqlParameter("cid", Request.QueryString["cid"]));
paras.Add(new SqlParameter("wxmpcid", Request.QueryString["wxmpcid"]));System.Data.CommandType ct=System.Data.CommandType.Text;ControlInducingFieldName(true,true);

  

小结

ControlInducingFieldName 方法目前可支持如下控件返写:

(1)Label 控件的 Text 属性

(2)Literal 控件的 Text 属性

(3)TextBox 控件的 Text 属性

(4)DropDownList 控件的 Text 属性

(5)HyperLink 控件的 NavigateUrl 属性

(6)HtmlLink 控件的 Href 属性

另外对于 HtmlControls ,如果值为 "visible:true" 或 "visible:false",则可以对控件进行 Visible 的设置,这是根据项目实际的一些需要进行的功能实现。以上就是关于控件数据返写的介绍,我们可以根据自己的实际需要进行改造和控件识别的扩充,本示例代码仅供您参考。 

感谢您的阅读,希望本文能够对您有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/34237.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL优化示例

友情链接 •分布式计算框架系列文章&#xff08;一&#xff09;MR框架工作流程以及框架限制 •分布式计算框架系列文章&#xff08;二&#xff09;数据倾斜现象诱因、原理、影响&#xff0c;以及星环对此的应对策略 •分布式计算框架系列文章&#xff08;三&#xff09;星环…

element-ui table使用type=‘selection‘复选框全禁用-全选禁用_elementui table禁用全选

问题点&#xff1a;当条件数据全被禁用时&#xff0c;全选按钮不是禁用的状态。 复选框全被禁用时&#xff0c;全选按钮将被隐藏 问题总结&#xff1a; 当条件数据全被禁用时&#xff0c;全选按钮也变成禁用的状态&#xff0c;而不是隐藏。有会做的小伙伴希望跟帖。谢谢&#x…

Redis-数据类型-zset

文章目录 1、查看redis是否启动2、通过客户端连接redis3、切换到db4数据库4、将一个或多个member元素及其score值加入到有序集key当中5、升序返回有序集key6、升序返回有序集key&#xff0c;让分数一起和值返回的结果集7、降序返回有序集key&#xff0c;让分数一起和值返回到结…

【AI应用探讨】—多模态小模型应用场景

目录 1. 移动设备和边缘计算 2. 智能家居 3. 医疗健康 4. 教育科技 5. 社交媒体分析 1. 移动设备和边缘计算 实时性要求高&#xff1a;在自动驾驶、即时翻译等应用中&#xff0c;模型需要快速响应以确保安全和准确性。多模态小模型由于具有低延迟特性&#xff0c;非常适合…

同城跑腿APP开发,随叫随到超方便!

随着移动互联网的发展和人们生活节奏的加快&#xff0c;越来越多的人们没有闲暇的时间来做一些繁琐的事情&#xff0c;比如说买药、挂号、排队、送花、取文件等等。如果没有时间去处理这些事情怎么办&#xff1f;开发同城跑腿APP&#xff0c;提供跑腿服务&#xff0c;随时办事随…

【C++】循环、控制流语句、指针、引用

8、循环&#xff08;loops&#xff09;&#xff08;1&#xff09;for loops for循环非常灵活&#xff0c;可以做很多事情。上图红框框出来的代码块就是一个for循环。 for是关键字 for后面内容分为三部分&#xff0c;每部分用分号&#xff1b;隔开 第一部分A是变量的声明&…

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维&#xff0c;在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现&#xff1a;坐标校正&#xff0c;我们如何使漫无目的鼠标点击变得有序化和可控化呢&#xff1f; 目录 一、从鼠标监听到获取坐标 1.MouseListener和Mouse…

你知道聚合函数SUM和COUNT在使用上的区别?

COUNT()&#xff1a;用于行数计数&#xff0c;可以是总行数、某列的非空值数量或者某列的唯一值数量。 SUM()&#xff1a;用于求和&#xff0c;只能对数值列进行操作 处理NULL值时 COUNT(*)&#xff1a;包含 NULL 值的行。 COUNT(column_name)&#xff1a;忽略 NULL 值。 SUM…

VBA学习(16):工作表事件示例:输入数据后锁定单元格

在工作表单元格中输入数据后&#xff0c;该单元格就被锁定&#xff0c;不能再编辑。 打开VBE&#xff0c;在工程资源管理器中双击该工作表名称打开其代码模块&#xff0c;在其中输入下面的代码&#xff1a; 假设整个工作表的LockedFalse Private Sub Worksheet_Change(ByVal …

用JavaScript实现了一个简单的图像坐标点标注工具

这段代码实现了一个简单的图像标注工具&#xff0c;允许用户在加载的图像上进行点选标注&#xff0c;并且通过右键确认一个点序列来形成一个多边形。 标注效果如下 实现代码如下 <!DOCTYPE html> <html lang"en"> <head><meta charset"U…

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n 1005; // n根据题目中节点数量而定&#xff0c;一般比节点数量大一点就好 vector<int> father vector<int> (n, 0); // C里的一种数组结构// 并查集初始化 void init() {for (int i 0; i < n; i)…

20个Python字典映射技巧,让数据处理更高效

字典作为Python的日常工具&#xff0c;拥有快速查找、高效存储等特性&#xff0c;是数据处理的必备神器。让我们一起揭开它的15个隐藏技巧&#xff0c;让你的代码飞起来&#xff01; 1. 初始化小技巧&#xff1a;快速创建字典 # 使用zip函数结合列表&#xff0c;一键成字典 k…

数据治理如何评估

在当今数字化时代&#xff0c;数据被认为是企业的重要资产之一&#xff0c;而有效的数据治理则成为确保数据价值和可靠性的关键。数据治理不仅仅是关于数据的管理&#xff0c;更是关于组织如何评估、保护和优化数据资产的过程。经过数聚多年的项目经验&#xff0c;我们就来从企…

深入解析Java编写优雅代码的技巧(下)

# 深入解析Java编写优雅代码的技巧&#xff08;下&#xff09;在上一篇文章中&#xff0c;我们介绍了如何在Java中编写优雅代码的几种基本技巧&#xff0c;包括代码风格、命名规范、注释和编写简洁代码的原则。本文将继续探讨代码重构、设计模式和单元测试等高级技巧。## 4. 代…

AI绘画Stable Diffusion 超强一键去除图片中的物体,免费使用!

大家好&#xff0c;我是设计师阿威 在生成图像时总有一些不完美的小瑕疵&#xff0c;比如多余的物体或碍眼的水印&#xff0c;它们破坏了图片的美感。但别担心&#xff0c;今天我们将介绍一款神奇的工具——sd-webui-cleaner&#xff0c;它可以帮助我们使用Stable Diffusion轻…

docker使用及Dockerfile编写

docker 基础使用 Linux安装docker # Linux安装docker服务 sudo apt install docker.io# 把普通用户加入到docker组中&#xff08;解决docker ps权限问题&#xff0c;$USER通常为用户名&#xff09; sudo gpasswd -a $USER docker newgrp dockerdocker 环境路径配置 # 修改系…

Rust高性能日志库tklog0.0.8—支持mod设置参数

tklog是rust高性能结构化日志库&#xff0c;支持同步日志&#xff0c;异步日志&#xff0c;支持自定义日志的输出格式&#xff0c;支持按时间&#xff0c;按文件大小分割日志文件&#xff0c;支持日志文件压缩备份&#xff0c;支持官方日志库标准API&#xff0c;支持mod独立参数…

怎么将文件免费扫描?这篇文章教你几个文件扫描方法

随着时间的流逝&#xff0c;我们所珍藏的纸质文件可能会面临破损和丢失的风险。 为了确保这些宝贵的资料得到妥善保管&#xff0c;将它们转换为电子格式并存储于电脑中无疑是一个明智之举。 那么&#xff0c;我们应当如何将这些纸质资料转换为易于管理和访问的电子文档呢&…

CMake基础教程

用法 cmake -B build // 配置&#xff0c;在源码目录用 -B 直接创建 build 目录并生成 build/Makefile cmake --build build -j4 // 构建&#xff0c;Linux会调用make&#xff0c;Windows会调用devenv.exe cmake --version 定义 -DCMAKE_INSTALL_PREFIX/opt/openvdb-8.0 /…

C++必修:模版的入门到实践

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ &#x1f388;&#x1f388;养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; 所属专栏&#xff1a;C学习 贝蒂的主页&#xff1a;Betty’s blog 1. 泛型编程 首先让我们来思考一个问题&#xff0c;如何实现一个交换函数&#x…