绑定到其它元素

<Grid> 
    <StackPanel> 
        <TextBox x:Name="textbox1" /> 
        <Label Content="{Binding ElementName=textbox1, Path=Text}" /> 
    </StackPanel>
</Grid>
 
绑定到静态资源
<Window.Resources> 
        <ContentControl x:Key="text">Hello, World!</ContentControl>
</Window.Resources>
<Grid> 
    <StackPanel> 
        <Label x:Name="label1" Content="{Binding Source={StaticResource text}}" /> 
    </StackPanel>
</Grid>
<STRONG>3. 绑定到自身</STRONG>
<Grid> 
    <StackPanel> 
        <Label x:Name="label1" Content="{Binding RelativeSource={RelativeSource Self}, Path=Name}" /> 
    </StackPanel>
</Grid>
绑定到指定类型的父元素
<Grid x:Name="Grid1"> 
        <StackPanel> 
            <Label x:Name="label1" Content="{Binding RelativeSource={RelativeSource FindAncestor,  
                AncestorType={x:Type Grid}}, Path=Name}" /> 
        </StackPanel>
</Grid>
 
绑定到对象
public class Person  
   {  
       public string Name { get; set; }  
       public int Age { get; set; }  
   }
<StackPanel x:Name="stackPanel">  
        <StackPanel.DataContext>  
            <local:Person Name="Jack" Age="30"></local:Person>  
        </StackPanel.DataContext>  
        <TextBlock  Text="{Binding Path=Name}"></TextBlock>  
        <TextBlock Text="{Binding Path=Age}"></TextBlock>         
</StackPanel>

绑定到集合
public class Person  
    {  
        public string Name { get; set; }  
        public int Age { get; set; }  
    }

public class PersonList : ObservableCollection<Person>  
    { }
<Window.Resources>  
       <local:PersonList x:Key="person">  
           <local:Person Name="Jack" Age="30"></local:Person>  
           <local:Person Name="Tom" Age="32"></local:Person>  
       </local:PersonList>  
   </Window.Resources>  
   <StackPanel x:Name="stackPanel">  
       <ListBox  ItemsSource="{Binding Source={StaticResource ResourceKey=person}}" 
                  DisplayMemberPath="Name">             
       </ListBox> 
</StackPanel>
 
DataContext共享源
我们需要将同一资源绑定到多个 UI 元素上,很显然到处写 "{Binding Source={StaticResource person}}" 是件很繁琐且不利于修改的做法。WPF 提供了一个称之为 "数据上下文 (DataContext)" 的东西让我们可以在多个元素上共享一个源对象,只需将其放到父元素 DataContext 属性即可。当我们不给 Binding 扩展标志指定 Source 属性时,它会自动寻找上级父元素的数据上下文。
<Window.Resources>  
        <local:PersonList x:Key="person">  
            <local:Person Name="Jack" Age="30"></local:Person>  
            <local:Person Name="Tom" Age="32"></local:Person>  
        </local:PersonList>  
    </Window.Resources>  
    <StackPanel x:Name="stackPanel" DataContext="{StaticResource person}">  
        <ListBox  ItemsSource="{Binding}" 
                   DisplayMemberPath="Name">             
        </ListBox>  
    </StackPanel>
 
使用XML作为Binding的源
XML:
<?xml version="1.0" encoding="utf-8" ?> 
<PersonList>  
  <Person Id="1">  
    <Name>Jack</Name>  
  </Person>  
  <Person Id="2">  
    <Name>Tom</Name>  
  </Person>  
  <Person Id="3">  
    <Name>Justin</Name>  
  </Person>  
  <Person Id="4">  
    <Name>David</Name>  
  </Person> 
</PersonList>

XAML:
<StackPanel>  
       <ListView x:Name="personListView">  
           <ListView.View>  
               <GridView>  
                   <GridViewColumn Header="Id" Width="100" 
                                    DisplayMemberBinding="{Binding XPath=@Id}"/>  
                   <GridViewColumn Header="Name" Width="100" 
                                    DisplayMemberBinding="{Binding XPath=Name}"/>  
               </GridView>  
           </ListView.View>  
       </ListView>     
       <Button Click="Button_Click">Load Data</Button>  
   </StackPanel>

private void Button_Click(object sender, RoutedEventArgs e)  
 {  
            XmlDocument xmlDocument = new XmlDocument();  
            xmlDocument.Load("Person.xml"); 
            XmlDataProvider xdp = new XmlDataProvider();  
            xdp.Document = xmlDocument;  
            xdp.XPath = @"/PersonList/Person"; 
  
            this.personListView.DataContext = xdp;  
            this.personListView.SetBinding(ListView.ItemsSourceProperty, new Binding());  
        }

WPF绑定方式的更多相关文章

  1. wpf中UserControl的几种绑定方式

    我们经常会抽取一些可重用的控件,某个属性是否需要重用,直接决定了这个属性的绑定方式. 1.完全不可重用的控件 有一些与业务强相关的控件,它们的属性完全来自ViewModel,越是相对复杂的控件,越容易 ...

  2. WPF快速入门系列(4)——深入解析WPF绑定

    一.引言 WPF绑定使得原本需要多行代码实现的功能,现在只需要简单的XAML代码就可以完成之前多行后台代码实现的功能.WPF绑定可以理解为一种关系,该关系告诉WPF从一个源对象提取一些信息,并将这些信 ...

  3. WPF 绑定StaticResource到控件的方法

    原文:WPF 绑定StaticResource到控件的方法 资源文件内的属性能否直接通过绑定应用到控件?答案是肯定的. 比如,我们要直接把下面的<SolidColorBrush x:Key=&q ...

  4. WPF绑定各种数据源之object数据源

    一.WPF绑定各种数据源索引 WPF 绑定各种数据源之Datatable WPF绑定各种数据源之object数据源 WPF绑定各种数据源之xml数据源 WPF绑定各种数据源之元素控件属性 Bindin ...

  5. RegisterAttached 两种绑定方式

    RegisterAttached 含义:使用指定的属性名称.属性类型和所有者类型注册附加属性 绑定方式:C#绑定.WPF绑定 例:需求DataViewModel为DataView的VM层,在DataV ...

  6. WPF 绑定父类属性

    原文:WPF 绑定父类属性 1.绑定父控件的属性. <ContextMenu x:Key="ContextMenuColoum"> <MenuItem Heade ...

  7. WPF绑定(Binding)(4)

    什么是绑定(Binding)? 在winform中, 我们常常会用到各种类型的赋值, 例如: button1.Text="Hello"; label.Text="Hell ...

  8. 对比MFC资源文件谈谈WPF布局方式

    对比MFC资源文件谈谈WPF布局方式 MFC方式 对于传统的MFC基于UI的应用程序设计通常分两步走,首先是设计UI,使用的是RC文件,然后是代码文件,对RC文件进行操作,如下面Figure 1 的基 ...

  9. [Spring MVC] - SpringMVC的各种参数绑定方式

    SpringMVC的各种参数绑定方式 1. 基本数据类型(以int为例,其他类似):Controller代码: @RequestMapping("saysth.do") publi ...

随机推荐

  1. iOS Simulator功能介绍关于Xamarin IOS开发

    iOS Simulator功能介绍关于Xamarin IOS开发 iOS Simulator功能介绍 在图1.38所示的运行效果中,所见到的类似于手机的模型就是iOS Simulator.在没有iPh ...

  2. ajax的参数

    http://www.w3school.com.cn/jquery/ajax_ajax.asp call.addAllremark = function(data){ $.ajax({ url:cal ...

  3. 字符串截取函数substr和substring的不同及其相关说明

    1.substr 方法 功能:用于返回一个从指定位置开始的指定长度的子字符串,从“母字符串”的“指定位置”开始提取“指定长度”的“子字符串”. 语法:stringObject.substr(start ...

  4. Ubuntu 安装Redis体验

      背景:由于之前一直没有试过Linux的环境,今天加了内存之后,虚拟机开了3G,速度大大提高,对照博客试一下安装Redis的过程.   体验: 下载源码,解压,编译 $ wget http://do ...

  5. TYVJ P1020 导弹拦截 Label:水

    题目描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度.某天,雷达捕捉到敌国的导弹 ...

  6. 原生js记住密码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. Configuration of OpenCV2.1.0 with VS2010

    Add in the system Path: C:\Program Files (x86)\OpenCV-2.1.0\build\bin\Debug Project->Project Prop ...

  8. JS让input按钮不能点击

    <input value="开通" type="button" id="tijiao" class="button" ...

  9. 词频统计(WEB版)

    通过点击浏览按钮输入文件: 点击查询按钮后返回结果: 前台代码: <%@ Page Language="C#" AutoEventWireup="true" ...

  10. div居中(内容+元素:水平+垂直)

    内容水平居中 text-align: center; 内容垂直居中 /*第一种 行内垂直居中*/ height: 43px; line-height:43px; /*我们将行距增加到和整个div一样高 ...