开发者

Fill WPF listbox with string array

开发者 https://www.devze.com 2022-12-28 09:28 出处:网络
Instead of adding each item one by one to the ListBox destinationList from the string array m_List like this:开发者_StackOverflow

Instead of adding each item one by one to the ListBox destinationList from the string array m_List like this:开发者_StackOverflow

foreach (object name in m_List)
{
    destinationList.Items.Add((string)name);
}

Is there any better way I can do it?

I don't want to bind the data to the destinationList since I want to delete some entries from the ListBox later on.


If you only want to express it more elegantly, then perhaps this will work.

stringList.ForEach(item => listBox1.Items.Add(item));


HTH:

    string[] list = new string[] { "1", "2", "3" };

    ObservableCollection<string> oList;
    oList = new System.Collections.ObjectModel.ObservableCollection<string>(list);
    listBox1.DataContext = oList;

    Binding binding = new Binding();
    listBox1.SetBinding(ListBox.ItemsSourceProperty, binding);

    (listBox1.ItemsSource as ObservableCollection<string>).RemoveAt(0);

Just use (ItemSource as ObservableCollection)... to work with items, and not Items.Add etc.


use OberservableCollection


Okay.. if binding is not an option - and I would probably go that way if it was... then the only more efficient way to populate the listbox would be to do it in parallel.

(For this to work I am assuming you have the .Net 4 runtime, or the PLinq libraries installed)

The following code would show massive improvements on a multicore machine provided the collection of data was large enough to warrant the overhead of the initial setup. So this would only be viable for larger arrays.

Parallel.ForEach(list, r => destinationList.Items.Add(r));

Else I don't see anything wrong with your foreach loop.

0

精彩评论

暂无评论...
验证码 换一张
取 消