在.net中,数据绑定对程序的快速开发提供了一个便利,像一些列表控件,combox,Listbox,datagridview等,都是通过这种简单的绑定,来实现批量数据的展示。WPF中的数据绑定又提升了一个等级,不但数据库与UI控件能绑定,UI控件与UI控件的绑定都可以实现,并且绑定到控件上的属性也得到了大的扩展(以前最常用的绑定属性是DataSource)。

数据绑定(一)_第1张图片

绑定这个词就告诉我们,应该是把两个或更多的事或物结合在一起,是的,在WPF中的绑定,是把绑定目标和绑定源(通常是数据集合,对象,元素控件)结合在一起,这种结合是有选择的结合,所以在绑定目标和绑定源中,都要先择出绑定的属性。举个例子,我们有一个下拉列表,有一个文本框,我们希望选中的下拉项,显示到文本框中,这时,下拉列表就是一个绑定源,选中的项就是绑定源属性,文本框就是绑定目标,Text属性就是绑定目标属性。要注意的是,绑定源没有限制,可以是WPF的元素控件,也可以是一个集合,可以是对象,可以是XML数据等,但绑定目标中的绑定属性就有限制了,它必需是依赖项属性。

在绑定中,绑定源和绑定目标有一个桥梁,这个桥量是有方向的,这个方向是通过一个BindingMode枚举来区分的,这个枚举代码如下:

    public enum BindingMode

    {

       // 绑定源和绑定目标双方触发更新

        TwoWay = 0,

       // 绑定源触发绑定目标更新

        OneWay = 1,

        //绑定源触发绑定目标更新一次(只是在初始化的时侯)

        OneTime = 2,

        //绑定目标触发绑定源更新

        OneWayToSource = 3,

        //默认值,根据控件来确定是单向还是双向,一般情况下,可编辑控件是双向绑定,不可编辑控件是单向绑定(即OneWay方式)

        Default = 4,

    }

}

接下来,先看一个简单的元素控件和元素控件的绑定。

Content是用绑定来实现的,当然Lable是绑定目标对象,Content就是绑定目标属性了,绑定源就是ElementName=textBox1,绑定源属性是Path=Text,由于Lable是不可编辑的,所以Lable.Content的变化只能依据TextBox.Text了。

上面是通过属性绑定,代码绑定如下:

            label1.DataContext = textBox1;

            label1.SetBinding(Label.ContentProperty, "Text");

接下来,绑定一个对象,对象生成的类如下:

public class Person

    {

int age;

public int Age

        {

get

            {

return age;

            }

set

            {

                age = value;

            }

        }

string name;

public string Name

        {

get

            {

return name;

            }

set

            {

                name = value;

            }

        }

    }

接下来,用TextBox来显示这个对象的Age属性,可以承载TextBox 的窗里的构造里实例化一个对象:

person = new Person();

person.Age = 25;

textBox1.DataContext = person;

让文本框的数据绑定到person这个对象上(也以把person对象绑定到textBox1的父对元素的DataContext上)。

然后把textBox1的Text绑定到对象的Age上,可以用标签属性,也可以用代码,分别如下:

textBox1.SetBinding(TextBox.TextProperty, "Age")

上面的绑定都比较简单,有时间要进行比较特别的绑定,那就是绑定源属性与绑定目标属性类型不一样,这样的话就需要作一个类型转换。在窗体上放置一个label2,它的背景色根据Age的变化而变化,小于等20岁为红色,大于20小于等于50为绿色,大于50为蓝色,这如何实现?

首先得构造类型转换类,在绑定中的转换,微软提供了一个接口IValueConverter,我们必需实现这个接口,才能实现绑定的类型转换。转换定意如下:

[ValueConversion(typeof(int), typeof(Brush))]

class ConvertClass : IValueConverter

    {

public object Convert(object value, Type targetType, object parameter, CultureInfo culture)

        {

if (targetType != typeof(Brush))

            {

return null;

            }

int age = int.Parse(value.ToString());

SolidColorBrush scb = Brushes.White; ;          

if (age <= 20)

            {

                scb = Brushes.Red;

            }

if (age <= 50 && age > 20)

            {

                scb = Brushes.Green;

            }

if (age > 50)

            {

                scb = Brushes.Blue ;

            }

return scb;

        }

public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)

        {

throw new Exception();

        }

    }

这个接口有两个方法,一个Convert和一个ConvertBack,即两个类型的转换“来”和转换“去”。

在XAML元素中设置,首先设置一个Windows资源(就类似于实例化一个ConvertClass对象一样)

然后绑定label2:

代码实现如下:

Binding bd = new Binding();

  bd.Path = new PropertyPath("Age");

  bd.Converter = new ConvertClass();

  label2.SetBinding(Label.BackgroundProperty, bd);