Noob question... I'm trying to display a List in a textbox... unfortunately, my code only displays the first element in the list...
private void Form1_Load(object sender, EventArgs e)
{
List<String> vegetables = new List<String>();
vegetables.Add("tomato");
vegetables.Add("carrot");
vegetables.Add("celery");
vegetables.Add("potato");
textBox1.Text = displayMembers(vegetables);
}
public string displayMembers(List<String> vegetables)
{
foreach (String s in vegetables)
{
return s.ToString();
}
return null;
}
How do I get the textBox to display all of the members? Where is my mistake?
You're doing a foreach, but returning at the first element. This is going to cause it to just display the first element.
Instead, you probably want to do something like:
This uses String.Join to "stitch together" the vegetables into a single string, which can then be shown in a TextBox.
Use string.Join():
The answer was closer and easier than you thought :)
Note: as mentioned in the comments, this particular function has several overloads added in v4.0 of the .Net framework. If you want to see what is available for earlier versions use the
Other Versions
dropdown just under the title on the MSDN doco page.Once you
return s.ToString()
, the rest of that method stops running.A method cannot return multiple things.
You probably want to write
You need to concatenate the strings somehow, like
or
Try this: