我对C#很陌生,当我按下按钮时,我正试图将矩形的高度更改为文本框中数字的值。
所以当我硬编码时,我得到了
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
rct2010.Height = 150;
}
这是没有texbox并且工作正常。 如果我使用文本框,我想我必须这样做:
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
rct2010.Height = txt2010.Text;
}
但这不起作用。有人可以帮我吗?
答案 0 :(得分:0)
高度是一个整数,但Text是一个字符串。如果字符串无法解析为整数,这是不安全的,但它适用于您的简单示例。
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
rct2010.Height = int.Parse(txt2010.Text);
}
为了安全起见,你会使用TryParse。
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
int height;
if(int.TryParse(txt2010.Text,out height))
{
rct2010.Height = height;
}
else
{
rct2010.Height = 150;
}
}
答案 1 :(得分:0)
将其转换为int
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
rct2010.Height = int.Parse(txt2010.Text);
}
或者你可以更进一步
private void btnGrafiek_Click(object sender, RoutedEventArgs e)
{
int i = 0;
if(int.TryParse(txt2010.Text, out i)
rct2010.Height = i;
else
MessageBox.Show("That's not a number");
}
答案 2 :(得分:0)
大概Height
的类型是int
,因此分配类型string
的值将不起作用,并且您将得到一个编译时错误,如此(感觉自由澄清);你需要转换类型,例如:
int height = 0;
if (int.Parse(txt2010.Text, out height)) {
rct2010.Height = height;
}
TryParse
(与其他建议的Parse
相反)将确保您的应用程序在无法解析值时(即它是错误的,意外的输入)不会遇到异常。但是,另一方面,这意味着您的应用程序显然对输入没有任何作用(因为它没有),因此您可能希望使用else
大小写来通知用户。