如何在两个页面之间传递DataTable

本文介绍了ASP.NET Web Forms中三种常见的页面间传值方法:使用QueryString、使用Session变量及Server.Transfer方法。详细解释了每种方法的实现步骤与应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载地址:http://bbs.youkuaiyun.com/topics/60089625

SP.NET WEB FORMS 页面间的传值方法

       ASP.NET WEB FORMS  给开发者提供了极好的事件驱动开发模式。然而这种简单的应用程序开发模式却给我们带来了一些小问题,举个例子,在传统的ASP应用程序中,你能够通过POST方法很容易的把一个值或多个值从一个页面传送到另一个页面,用同样的方法在ASP.NET中实现有点麻烦。在这里,我们可以通过其他方式来解决这种情形。ASP.NET为我们提供了三种方式,一种是可以通过用QueryString来传送相应的值,再一种是通过session变量来传送相应的值,还有就是通过Server.Transfer方法来实现。下面分别一一介绍:


一、使用Querystring
Querystring是一种非常简单的传值方式,其缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象。如果你想传递一个安全性不是那么太重要或者是一个简单的数值时,用此方法最好不过了。下面通过一个小例子来完成传值工作,步骤如下:
1、创建一个web form
2、在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2 
3、为button按钮创建click事件
代码如下:
private void Button1_Click
(object sender, System.EventArgs e)
{
 string url;
 url="webform2.aspx?name=" + 
  TextBox1.Text + "&email=" + 
  TextBox2.Text;
 Response.Redirect(url);
}
4、新建一个目标页面命名为webform2
5、在webform2中放置两个Label1,Label2
在webform2的Page_Load中添加如下代码:
private void Page_Load
(object sender, System.EventArgs e)
{
 Label1.Text=Request.QueryString["name"];
 Label2.Text=Request.QueryString["email"];
}
运行,即可看到传递后的结果了。

二、使用Session变量

使用Session变量传值是一种最常见的方式了,此中方式不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed后,变量才会消失。举个例子看看:
1、创建一个web form
2、在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2 
3、为button按钮创建click事件
代码如下:
private void Button1_Click
(object sender, System.EventArgs e)
{
        Session["name"]=TextBox1.Text;
 Session["email"]=TextBox2.Text;
 Response.Redirect("webform2.aspx");
}
4、新建一个目标页面命名为webform2
5、在webform2中放置两个Label1,Label2
在webform2的Page_Load中添加如下代码:
private void Page_Load
(object sender, System.EventArgs e)
{
 Label1.Text=Session["name"].ToString();
 Label2.Text=Session["email"].ToString();
 Session.Remove("name");
 Session.Remove("email");
}
运行,即可看到传递后的结果了。

自己写的C#常用类库,使用时请先添加引用:UsrCustomFun.dll、DevComponents.DotNetBar2.dll,压缩包内的其他文件请与UsrCustomFun.dll放置同一目录,然后在程序中引用命名空间:using UsrCustomFun;包括: 1.自定义MessageBox,消息内容与错误代码分开,使用了6个重载方式。调用方法例子: UserMessageBox.UsrShow("执行SQL查询出错!", "数据库错误", ec.Message.ToString()); 2.等待提示窗口,使用了3个重载方法。 打开:UserWaitBox.UsrShow("等待信息"); 关闭:UserWaitBox.UsrClose(); 3.打印DataGridView,使用了9个重载方式,可自定义标题与打印样式: DataGridViewPrint.PrintDgv(dataGridView); 4.DataTable导出为Excel,3个重载方式: DataTableToExcel.DtToExcel(DataTable); 5.DataTable生成Pdf文件,6个重载方式: UsrExport.ExPdf(dataTable); 6.XML文件操作,可根据XML文件节点、路径来读取、修改、写入XML: UserXml.ReadXml(string XML的路径); UserXml.ReadXmlElement(string XML的路径,节点名称); UserXml.WriteXmlElement(XML路径,节点名称,内容); 7.数据库操作,目前有Access、SqlServer、Oracel (7.1)先配置数据库连接字符串: UsrCustomFun.SqlConn.SqlParameters下根据数据库类型返回一个数据库连接字符串。 (7.2)再执行数据库操作: (7.2.1)UsrCustomFun.SqlConn.SqlConnAccess下为Access的数据库操作,可根据SQL返回int型、string型、DataTable、DataReader、DataSet及无返回操作。 (7.2.2)UsrCustomFun.SqlConn.SqlConnOracle,操作类型同7.2.1 (7.2.3)UsrCustomFun.SqlConn.SqlConnSqlServer,操作类型同7.2.1
### 使用 XtraReport 绑定多个无关的 DataTable 实例 在 DevExpress 的 `XtraReport` 中,如果需要展示来自多个无直接关系的 `DataTable` 实例的数据,则可以通过以下方式实现: #### 1. 创建独立的数据源 每个 `DataTable` 都可以作为单独的数据源。这些数据表无需具有任何关联关系即可分别绑定到报告的不同部分。 ```csharp // 定义两个独立的 DataTable DataTable table1 = new DataTable("Table1"); table1.Columns.Add("ColumnA", typeof(string)); table1.Rows.Add("Value A1"); DataTable table2 = new DataTable("Table2"); table2.Columns.Add("ColumnB", typeof(int)); table2.Rows.Add(42); ``` #### 2. 将 DataTable 添加到统一的 DataSet 为了简化管理,可将所有的 `DataTable` 放入同一个 `DataSet` 中。这不会改变它们之间的独立性,但有助于集中管理和传递给报告引擎。 ```csharp DataSet dataSet = new DataSet(); dataSet.Tables.Add(table1); dataSet.Tables.Add(table2); report.DataSource = dataSet; // 设置整个 DataSet 为 DataSource ``` #### 3. 配置子报表或分组显示 由于不同的 `DataTable` 是相互独立的,在设计阶段需明确指定哪些控件对应哪个数据表。以下是两种常见的方式: - **使用主从结构** 如果希望在一个页面中同时展示不同表格的内容,可通过设置 `XRControl.DataMember` 来区分具体的数据成员。 ```csharp XRLabel labelFromTable1 = new XRLabel(); labelFromTable1.DataBindings.Add("Text", report.DataSource, "Table1.ColumnA"); // 显示 Table1 的 ColumnA XRLabel labelFromTable2 = new XRLabel(); labelFromTable2.DataBindings.Add("Text", report.DataSource, "Table2.ColumnB"); // 显示 Table2 的 ColumnB ``` - **嵌套子报表** 当某些数据不适合在同一区域展示时,可以选择创建子报表并将其链接至父报表中的某个字段。 ```xml <!-- 子报表配置 --> <Subreport> <DataSource>Table2</DataSource> <DetailBand> <Label FieldName="ColumnB" /> </DetailBand> </Subreport> ``` 对于 XML 数据的情况,需要注意特殊处理[^2]。即当采用 XML 文件作为输入时,应确保设置了 `XmlDataPath` 并清除了默认的 `DataSource` 属性。 --- ### 总结 通过以上方法能够灵活地利用多个不相关的 `DataTable` 构建复杂报表。关键是合理分配各数据表的作用域以及正确映射其字段到可视化组件上。 ```csharp public void BindMultipleTables(XtraReport report) { var ds = CreateSampleDataset(); // 自定义函数返回包含多个 DataTable 的 DataSet report.DataSource = ds; ConfigureControls(report); // 调整控件绑定逻辑以适应多表需求 } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值