我在存儲和顯示數據表中的值時遇到了問題。我的目標是爲數據表添加一個值,重新加載頁面,然後顯示帶有附加值的數據表並提供輸入更多的功能。目前,我甚至無法獲取數據表。我確信這是將數據保存在會話中的問題,但我根本無法從會話保存/加載工作。使用會話變量在數據表中創建和存儲值
我對你們可以給予我的任何幫助表示歉意,我很抱歉如果這件事真的非常簡單。似乎我只是需要第二個意見。
這是我目前的網頁,
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<p><asp:TextBox ID="txtName" runat="server"></asp:TextBox><asp:TextBox ID="txtEmail" runat="server"></asp:TextBox><asp:TextBox ID="txtAddress" runat="server"></asp:TextBox><asp:TextBox ID="txtInfo" runat="server"></asp:TextBox></p>
<p>
<asp:Button ID="btnAdd" runat="server" Text="Add" OnClick="btnAdd_Click"/></p>
</div>
<div>
<table border="1">
<asp:Repeater ID="rptrData" runat="server">
<HeaderTemplate>
<tr>
<td>Name</td>
<td>Email</td>
<td>Address</td>
<td>Info</td>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><%#Eval("Name") %></td>
<td><%#Eval("Email") %></td>
<td><%#Eval("Address") %></td>
<td><%#Eval("Info") %></td>
</tr>
</ItemTemplate>
<AlternatingItemTemplate>
<tr>
<td><%#Eval("Name") %></td>
<td><%#Eval("Email") %></td>
<td><%#Eval("Address") %></td>
<td><%#Eval("Info") %></td>
</tr>
</AlternatingItemTemplate>
</asp:Repeater>
</table>
</div>
</form>
</body>
</html>
而且我的身後當前的代碼,
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Net.Mail;
using System.Net;
using System.Data;
using System.Collections;
namespace WebApplication1
{
public partial class WebForm1 : System.Web.UI.Page
{
public DataTable MyDT = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
DataTable MyDT = (DataTable)Session["MyDT"];
rptrData.DataSource = MyDT;
rptrData.DataBind();
}
}
protected void btnAdd_Click(object sender, EventArgs e)
{
//DataTable MyDT = new DataTable();
MyDT.Columns.Add("Name");
MyDT.Columns.Add("Address");
MyDT.Columns.Add("Email");
MyDT.Columns.Add("Info");
string Name = txtName.Text;
string Address = txtAddress.Text;
string Email = txtEmail.Text;
string Info = txtInfo.Text;
DataRow dtRow = MyDT.NewRow();
dtRow["Name"] = Name;
dtRow["Address"] = Address;
dtRow["Email"] = Email;
dtRow["Info"] = Info;
Session.Add("MyDT", MyDT);
}
}
}
您只想將列添加到數據表一次,我建議在頁面加載,而不是每次單擊添加按鈕。 –