刚开始使用 ReactiveUI。我基本上是用查询结果填充网格。我的视图模型目前看起来像这样。
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();
});
}
很多谢谢
小号