The DataSource property allows data binding on Windows Forms controls. With it we bind an array to a ListBox on the screen—and display all the strings. As changes are made to the List, we update the control on the screen.

This C# tutorial shows how to use DataSource. It updates elements in a ListBox.
First, your ListBox control, or any different kind of control you may have, has a DataSource property that can be assigned a value. You can assign a collection to it. Collections include arrays, Lists, and DataTables. The code that follows here is the first step.
Example that sets DataSource property [C#]
public partial class MainWindow : Form
{
List<string> _sideList = new List<string>();
public MainWindow()
{
InitializeComponent();
sideListBox1.DataSource = _sideList;
}
}
Description. It has a List collection field. The above Form, which is called MainWindow, has a member variable of the List generic type. This will be where we want to store the strings that will show on the ListBox.
List Examples ListBox TutorialConstructor. It has some routine setup code. The constructor and the partial class and InitializeComponent were autogenerated by the Designer and aren't really important here. In the constructor, it assigns a DataSource. This is the important part here. The DataSource property is assigned to the List member variable.
Partial ClassThe whole point here is that we want to add items to the ListBox. We can add items to the bottom or the top, or anywhere in better. A really good effect is adding items to the top, so they are easily seen. Here is a custom method that prepends a string to the top of the control, and then makes it display.
List Insert MistakeExample that uses BindingContext [C#]
private void AddListLine(string lineIn)
{
// Insert the string at the front of the List.
_sideList.Insert(0, lineIn);
// Force a refresh of the ListBox.
((CurrencyManager)sideListBox1.BindingContext[_sideList]).Refresh();
}
Explanation. The method receives a string and then Inserts it to the start of the member List, and then forces the ListBox to refresh. In the CurrencyManager type, 'Currency' refers to current, meaning it is used to ensure a control is current. The syntax at the end of the above example does a cast and a lookup to get the CurrencyManager and then Refreshes the ListBox.
So far we have seen the DataSource assignment and then the method AddListLine that inserts a string at the top of the ListBox. This setup allows us to simply send a string to the method and it will show up at the top of the ListBox—which is really neat.
Example that implements threaded DataSource [C#]
void backgroundWorker1_RunWorkerCompleted(object sender,
RunWorkerCompletedEventArgs e)
{
// Show some results from the BackgroundWorker task.
AddListLine("5000 games: " + (string)e.Result);
}
We used the DataSource property on a ListBox control in Windows Forms. By combining one List, DataSource and ListBox, and using CurrencyManager, we have a cool ListBox that will show the newest result on the top. This is far faster and simpler than dealing with TextBoxes. Together, these properties result in an interface that is versatile and easily maintained.
Windows Forms