将多个数据表列绑定到一个多行文本框

时间:2016-01-21 13:47:34

标签: c# data-binding binding datatable datatables

我正在尝试将文本框绑定到包含一行的数据表。但我希望文本框绑定到4列的串联。

我不确定在绑定过程中是否可以不这样做。

以下一个可以正常工作,但我也希望" SHIP_ADDRESS1"要连接到我的多行文本框。

shipToTextbox.DataBindings.Add("Text",dataTbl, "SHIP_TO");

在绑定过程中有没有办法做到这一点?

编辑:

我在DataTable中添加了一个扩展方法,如下所示:

public static DataTable Concatenates(this DataTable datatable, string columnName, params string[] columns)
    {
        var column = new DataColumn(columnName, typeof(String));
        datatable.Columns.Add(column);

        var concatenation = string.Empty;

        foreach (var c in columns)
        {
            if (string.IsNullOrEmpty(concatenation))
            {
                concatenation = datatable.Rows[0][c].ToString().Trim();
            }
            else
            {
                concatenation = concatenation + Environment.NewLine + datatable.Rows[0][c].ToString().Trim();
            }
        }

        datatable.Rows[0][column] = concatenation;

        return datatable;
    }

我称之为:

shipToTextbox.DataBindings.Add("Text", dt.Concatenates("SHIP", "SHIP_TO", "SHIP_ADDRESS1", "SHIP_ADDRESS2", "SHIP_ADDRESS3"), "SHIP");

这是一个可以接受的解决方案吗?有没有办法使用LINQ以更好的方式编写Concatenate扩展方法?

1 个答案:

答案 0 :(得分:-1)

如果您正在谈论xaml框架,您可以使用MultiValueConverters和ValueConverters。

然而,winforms绑定会生成两个重要且有用的事件:Format和Parse。

将数据从源提取到控件时会触发format事件,并且在将数据从控件拉回数据源时会触发Parse事件。如果处理这些事件,则可以在绑定期间更改/重新键入来回的值。