我有这个类(Class1
)从查询中检索值。现在我想让它面向对象,这就是为什么我这样写的。现在的问题是,TextBox
(TicketNum
)不会返回值并将其显示在表单中。我不知道为什么。帮助
public partial class Main : System.Web.UI.Page
{
private String _TicketNum;
public String TicketNum
{
get { return _TicketNum; }
set { _TicketNum = value; }
}
}
public class Class1
{
Main main = new Main();
public void SelectTop1()
{
using (SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString))
{
using (SqlCommand com_retrieve = new SqlCommand("usp_SelectTop1Ticket", con))
{
com_retrieve.CommandType = CommandType.StoredProcedure;
con.Open();
try
{
main.TicketNum = com_retrieve.ExecuteScalar().ToString();
MessageBox.Show("Ticket Has been saved. Your Ticket Number: " + com_retrieve.ExecuteScalar().ToString(), "Ticket Filed");
}
catch (SqlException)
{
MessageBox.Show("The database has encountered an error");
}
catch (Exception)
{
MessageBox.Show("The server has encountered an error");
}
}
}
}
}
protected void btn_Save_Click(object sender, EventArgs e)
{
Class1 selectTop1 = new Class1();
selectTop1.SelectTop1();
}
答案 0 :(得分:2)
您的字符串TicketNum将始终为空,因为您尚未为其指定值。
幸运的是,字符串不会自动连接到文本框,这将非常令人沮丧。
要将字符串分配给文本框,请:
string TicketNum = txtbox.Text;
根据您的问题的声音,情况可能并非如此,听起来您希望文本框此时显示在您的表单中。因此,要执行此操作,您需要为表单创建一个新的文本框。您可以在工具箱中或动态地执行此操作。我将向您展示如何动态地完成它:
TextBox txtbox = new TextBox();
txtbox.ID = "textBox1";
form1.Controls.Add(txtbox);
当然,您可以将这些文本框命名为更合适的名称。然后,您将返回到您的字符串ticketnum并更新它以调用名称文本框ID。
修改强>
我已回答了您的问题,但从查看您的评论后,我发现您的问题质量很差。听起来更像是要将主要类中的txtbox中的信息传递给此类。 OOP使这非常简单。在主类中,您需要将txtbox存储到字符串中。然后你需要在新类中创建一个构造函数,然后简单地将string参数传递给你的新类构造函数。
如果您对此不确定,我建议您查看Constructors,并查看全部OOP查看this msdn article。
Edit2
在SO成为谷歌之前,我相信你应该再次阅读OOP,你还没有理解它。在这个类中,您可以使用继承而不是在此类中调用主类,但不确定为什么要这样做。如果您阅读我给你的文章我会认为你现在已经看到了你的错误并解决了这个问题。
答案 1 :(得分:0)
看看以下内容:
public partial class Main : System.Web.UI.Page
{
public String TicketNum
{
get { return textbox.Text; }
set { textbox.Text = value; }
}
protected void btn_Save_Click(object sender, EventArgs e)
{
Class1 selectTop1 = new Class1();
TicketNum = selectTop1.SelectTop1();
}
}
public class Class1
{
public string SelectTop1()
{
// assign the value from SQL to the response variable
string response = "test";
return response;
}
}
请注意以下事项:
TicketNum
属性设置/获取textbox.Text
属性Class1
类SelectTop1
方法返回一个字符串值,该值在Main
类中使用(也许您甚至可以将其设置为静态,因此您不需要Class1
的实例叫它的课程)MessageBox
类用于WinForms,也许您应该使用一些JavaScript进行警报