从IObservable填充ReactiveCollection

时间:2013-02-02 11:56:21

标签: reactiveui

刚开始使用ReactiveUI。我基本上使用查询结果填充网格。我的viewmodel目前看起来像这样。

 public class QueryViewModel : ViewModelBase 
{

    private readonly ResultSet _resultSet = null;

    public ReactiveCollection<GridColumn> Columns { get; private set; }
    public ReactiveCollection<GridRow> Rows { get; private set; }

    public QueryViewModel()
    {
        _resultSet = ... run query

        Columns = new ReactiveCollection<GridColumn>(from c in _resultSet.Columns select new GridColumn(c));
        Rows = new ReactiveCollection<GridRow>(from r in _resultSet.Rows select new GridRow(r));

        //Rows = new ReactiveCollection<GridRow>();
        //_resultSet.ObservableRows
        //          .Subscribe(r => Rows.Add(new GridRow(r)));                     

    }    
}

正如你所看到的,当使用IEnumerable进行填充时我可以使它工作,但你可以从注释掉的位看到我不太确定从IObservable填充的方法。

请有人指出我正确的方向。

编辑:

对于完整的披露,我已经包含了ObservableRows的实现,以防我在这里犯了错误。

Return Observable.Create<Row>((o) => {
             var cn = New SqlConnection(connection);
             var cmd = New SqlCommand(sql, cn);
             var asyncReader = Observable.FromAsyncPattern<SqlDataReader>(cmd.BeginExecuteReader, cmd.EndExecuteReader);
             IDisposable subscription;
             Try {
                cn.Open();
                subscription = asyncReader().Subscribe(rdr => PublishRows(rdr, o, columns));
             }
             Catch Exception ex {
                o.OnError(ex);
             }

             Return Disposable.Create(() => { 
                  subscription.Dispose();
                  cmd.Dispose();
                  cn.Close();
                  cn.Dispose();
             });
}

很多thx

取值

1 个答案:

答案 0 :(得分:3)

怎么样:

Rows = _resultSet.ObservableRows.CreateCollection();