У меня есть оператор LINQ, который возвращает неявный тип. Я должен заставить этот тип быть ObservableCollection в моем приложении Silverlight 3. Конструктор ObservableCollection в Silverlight 3 только предоставляет пустого конструктора. Из-за этого я не могу непосредственно преобразовать свои результаты в ObservableCollection. Вот мой код:
ObservableCollection<MyTasks> visibleTasks = e.Result;
var filteredResults = from visibleTask in visibleTasks
select visibleTask;
filteredResults = filteredResults.Where(p => p.DueDate == DateTime.Today);
visibleTasks = filteredResults.ToList(); // This throws a compile time error
Как я могу пойти от переменной с неявно определенным типом до заметного набора?
Спасибо
Вы можете добавить элементы вручную, например:
visibleTasks = new ObservableCollection<MyTasks>();
foreach(var item in filteredResults)
visibleTasks.Add(item);
Вы можете сделать это в одной строке, используя следующий метод расширения:
///<summary>Adds zero or more items to a collection.</summary>
public static void AddRange<TItem, TElement>(this ICollection<TElement> collection, IEnumerable<TItem> items)
where TItem : TElement {
if (collection == null) throw new ArgumentNullException("collection");
if (items == null) throw new ArgumentNullException("items");
foreach (var item in items)
collection.Add(item);
}
visibleTasks = new ObservableCollection<MyTasks>();
visibleTasks.AddRange(filteredResults);
Вы можете написать метод расширения, который преобразует перечисление в ObservableCollection, например:
public static ObservableCollection<T> ToObservableCollection<T>(this IEnumerable<T> source)
{
ObservableCollection<T> obsColl = new ObservableCollection<T>();
foreach (T element in source)
{
obsColl.Add( element );
}
return obsColl;
}
Теперь вы можете вызвать следующий оператор:
visibleTasks = filteredResults.ToObservableCollection();
Используйте конструктор ObservableCollection
, который принимает IEnumerable
:
ObservableCollection<MyTasks> visibleTasks = e.Result;
var filteredResults = from visibleTask in visibleTasks
select visibleTask;
filteredResults = filteredResults.Where(p => p.DueDate == DateTime.Today);
visibleTasks = new ObservableCollection<MyTasks>(filteredResults); // This throws a compile time error