WPF元素绑定--简单

来源:互联网 发布:vb single double 编辑:程序博客网 时间:2024/04/28 10:49

数据绑定是一种关系,WPF从一个源对象提取一些信息,并使用这些信息设置目标对象的属性。数据绑定最简单的情形是,源对象是WPF元素而且源属性是依赖属性,依赖属性具有内置的更改通知支持。因此当在源对象中改变依赖属性的值时,会立即更新目标对象中的绑定属性。

将元素绑定到一起

  例如:滑块的拖动,改变TextBlock字体的大小,如果不采用元素绑定,需要为Silder控件添加ValueChanged事件。下面的示例是简单的元素绑定。

<Grid>
            <Slider Name="sliderFontSize" Margin="3" Minimum="1" Maximum="40" Value="10"
                TickFrequency="1" TickPlacement="TopLeft">
            </Slider>
            <TextBlock Margin="10,39,10,62" Text="Simple Text" Name="lblSampleText" FontSize="{Binding ElementName=sliderFontSize,Path=Value}">
            </TextBlock>        
</Grid>

这样当我们滑动滑动条的时候,标签的字体大小就会改变。

<Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"></RowDefinition>
            <RowDefinition Height="*"></RowDefinition>
            <RowDefinition Height="Auto"></RowDefinition>
            <RowDefinition />
        </Grid.RowDefinitions>
        <Slider Name="sliderFontSize" Margin="3" Minimum="1" Maximum="40" Value="10" TickFrequency="1" IsSnapToTickEnabled="True" TickPlacement="TopLeft"></Slider>
        <TextBlock Grid.Row="1" Text="Simple Text" Margin="10" Name="lblSampleText"
                   FontSize="{Binding ElementName=sliderFontSize,Path=Value,Mode=TwoWay}"
                   ></TextBlock>
        <StackPanel Orientation="Horizontal" Margin="5" Grid.Row="2">
            <TextBlock VerticalAlignment="Center" xml:space="preserve">Exact Size:</TextBlock>
            <TextBox Text="{Binding ElementName=lblSampleText, Path=FontSize, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}" Width="100"></TextBox>
        </StackPanel>
    </Grid>

就是在需要的地方,用到Mode这个属性,他是一个枚举类型,包括几个值

OneWay  当源属性变化时更新目标属性

TwoWay 源属性变化更新目标属性,目标属性更新源属性也更新

OneTime 最初根据源属性更新目标属性

Default 既可以双向,也可以单向。根据目标属性自动 调整,目标属性像textbox,就是双向,像textblock就是单向。