原文 http://www.cnblogs.com/mgen/archive/2011/06/19/2084553.html

示例程序:

如上程序截图,一目了然典型的主从模式绑定应用,如果里面的数据不是用XML来存储而是已经初始化好的C#对象(比如国家是Country类的对 象,名字是Name属性,Provinces属性保存一个Province集合,代表国家的省/州,Province类包含Name属性代表名 称,Cities属性代表一些列City类对象……)那么主从模式绑定可以很简单的这样写:

1. 设置最外层DataContext为一系列的“国家”(“国家”集合)

2. 国家ListBox直接绑定

3. 省/州ListBox的ItemsSource为: {Binding Path=Provinces} (或者/Provinces)

4. 城市ListBox的ItemsSource为: {Binding Path=Province/Cities}

(注意所有ListBox的IsSynchronizedWithCurrentItem都设置成True)

但是如果放在Xml数据上,由于绑定上要用到XPath属性而不是Path属性,因此上述传统方案不适用,解决方案就是通过直接绑定所属
ListBox的SelectedItem值,然后再在这个值上进行XPath查询。注意第二层绑定直接用XPath,没有绑定最外层ListBox的
SelectedItem。ListBox代码如下:

<HeaderedContentControl>

<ListBox ItemsSource="{Binding}"

DisplayMemberPath="@name"

IsSynchronizedWithCurrentItem="True"/>

</HeaderedContentControl>

<HeaderedContentControl Header="省/州"

Grid.Column="1">

<ListBox Name="lbxProvince"

ItemsSource="{Binding XPath=province}"

DisplayMemberPath="@name"

IsSynchronizedWithCurrentItem="True"/>

</HeaderedContentControl>

<HeaderedContentControl Header="城市"

Grid.Column="2">

<ListBox DataContext="{Binding ElementName=lbxProvince, Path=SelectedItem}"

ItemsSource="{Binding XPath=city}"

IsSynchronizedWithCurrentItem="True"/>

</HeaderedContentControl>

完整的XAML代码

<Window.Resources>

<XmlDataProvider x:Key="xml" XPath="/countries/country">

<!-- 示例数据 -->

<x:XData>

<countries xmlns="">

<country name="中国">

<province name="陕西">

<city>西安</city>

<city>宝鸡</city>

</province>

<province name="山西">

<city>太原</city>

<city>大同</city>

</province>

<province name="内蒙古自治区">

<city>呼和浩特</city>

<city>包头</city>

<city>集宁</city>

</province>

<province name="河北">

<city>石家庄</city>

<city>保定</city>

</province>

</country>

<country name="美国">

<province name="加利福尼亚">

<city>洛杉矶</city>

<city>圣迭戈</city>

</province>

<province name="福罗里达">

<city>杰克逊维尔</city>

<city>迈阿密</city>

</province>

</country>

</countries>

</x:XData>

</XmlDataProvider>

<Style TargetType="HeaderedContentControl">

<Setter Property="Template">

<Setter.Value>

<ControlTemplate TargetType="HeaderedContentControl">

<DockPanel>

<Border DockPanel.Dock="Top"

Margin="3"

CornerRadius="3"

Background="DarkRed">

<TextBlock Text="{TemplateBinding Header}"

HorizontalAlignment="Center"

Foreground="White"></TextBlock>

</Border>

<ContentPresenter ContentSource="Content"

ContentTemplate="{TemplateBinding ContentTemplate}"></ContentPresenter>

</DockPanel>

</ControlTemplate>

</Setter.Value>

</Setter>

</Style>

<Style TargetType="ListBoxItem">

<Setter Property="SnapsToDevicePixels" Value="true"/>

<Setter Property="OverridesDefaultStyle" Value="true"/>

<Setter Property="Template">

<Setter.Value>

<ControlTemplate TargetType="ListBoxItem">

<Border Name="Border"

Padding="2"

SnapsToDevicePixels="true">

<ContentPresenter />

</Border>

<ControlTemplate.Triggers>

<Trigger Property="IsSelected" Value="true">

<Setter TargetName="Border" Property="Background" Value="YellowGreen"/>

</Trigger>

</ControlTemplate.Triggers>

</ControlTemplate>

</Setter.Value>

</Setter>

</Style>

</Window.Resources>

<Grid DataContext="{Binding Source={StaticResource xml}}">

<Grid.ColumnDefinitions>

<ColumnDefinition></ColumnDefinition>

<ColumnDefinition></ColumnDefinition>

<ColumnDefinition></ColumnDefinition>

</Grid.ColumnDefinitions>

<HeaderedContentControl Header="国家">

<ListBox ItemsSource="{Binding}"

DisplayMemberPath="@name"

IsSynchronizedWithCurrentItem="True"></ListBox>

</HeaderedContentControl>

<HeaderedContentControl Header="省/州"

Grid.Column="1">

<ListBox Name="lbxProvince"

ItemsSource="{Binding XPath=province}"

DisplayMemberPath="@name"

IsSynchronizedWithCurrentItem="True"></ListBox>

</HeaderedContentControl>

<HeaderedContentControl Header="城市"

Grid.Column="2">

<ListBox DataContext="{Binding ElementName=lbxProvince, Path=SelectedItem}"

ItemsSource="{Binding XPath=city}"

IsSynchronizedWithCurrentItem="True"></ListBox>

</HeaderedContentControl>

</Grid>

作者:Mgen

出处:www.cnblogs.com/mgen

其他参考页面:我的软件和工程博客导读

WPF:在XmlDataProvider上使用主-从绑定(Master-Detail Binding)的更多相关文章

  1. 【转】在CentOS 8 / RHEL 8上配置主/从BIND DNS服务器

    转自: https://zh.codepre.com/centos-2700.html 前言 本指南描述了在CentOS 8 / RHEL 8 Linux上配置BIND DNS服务器所需的步骤.在Ce ...

  2. 转:WPF中ListBox的创建和多种绑定用法

    先从最容易的开始演示ListBox控件的创建. Adding ListBox Items下面的代码是向ListBox控件中添加多项ListBoxItem集合.XAML代码如下:<ListBox ...

  3. 整理:WPF中XmlDataProvider的用法总结

    原文:整理:WPF中XmlDataProvider的用法总结 一.目的:了解XmlDataProvider中绑定数据的方法 二.绑定方式主要有三种: 1.Xaml资源中内置: <!--XPath ...

  4. WPF使用MVVM(一)-属性绑定

    WPF使用MVVM(一)-属性绑定 简单介绍MVVM MVVM是Model(数据类型),View(界面),ViewModel(数据与界面之间的桥梁)的缩写,是一种编程模式,优点一劳永逸,初步增加一些逻 ...

  5. WPF使用MVVM(二)-命令绑定

    WPF使用MVVM(二)-命令绑定 上一节已经介绍了WPF的属性绑定,这使得我们只需要指定界面的DataContext,然后就可以让界面绑定我们的属性数据呢. 但是上一节还遗留了一个问题就是我们的按钮 ...

  6. WPF解决按钮上被透明控件遮盖时无法点击问题

    原文:WPF解决按钮上被透明控件遮盖时无法点击问题 IsHitTestVisible="False" 在控件上设置如上属性即可,即可让透明控件不触发点击效果

  7. WPF 让普通 CLR 属性支持 XAML 绑定(非依赖属性),这样 MarkupExtension 中定义的属性也能使用绑定了

    原文:WPF 让普通 CLR 属性支持 XAML 绑定(非依赖属性),这样 MarkupExtension 中定义的属性也能使用绑定了 版权声明:本作品采用知识共享署名-非商业性使用-相同方式共享 4 ...

  8. 示例:WPF开发的简单ObjectProperyForm用来绑定实体表单

    原文:示例:WPF开发的简单ObjectProperyForm用来绑定实体表单 一.目的:自定义控件,用来直接绑定实体数据,简化开发周期 二.实现: 1.绑定实体对象 2.通过特性显示属性名称 3.通 ...

  9. 整理:WPF中应用附加事件制作可以绑定命令的其他事件

    原文:整理:WPF中应用附加事件制作可以绑定命令的其他事件 目的:应用附加事件的方式定义可以绑定的事件,如MouseLeftButton.MouseDouble等等 一.定义属于Control的附加事 ...

随机推荐

  1. Windows下bat命令

    一.简单批处理内部命令简介  1.Echo 命令 打开回显或关闭请求回显功能,或显示消息.如果没有任何参数,echo 命令将显示当前回显设置.    语法  echo [{on│off}] [mess ...

  2. C语言实践——学生信息管理

    这是本人做的第一个实践项目,用的知识都是书上有的,没有很多很复杂的知识 同时因为没有学习 C语言 图形方面的知识,所以界面做得很丑,暂时先这样吧 源文件: #include <stdio.h&g ...

  3. PhotoShop-CS4使用-----如何对psd进行简单切图

    一.如何快速截图 1.如果图片为psd样式   2.要用放大器放大该图,选择放大器,放大后如图 3.开始切图  以其中一个为例,选中你所要选择切的图片 4. 选中后 5.选择文件---新建   6.此 ...

  4. Python核心编程笔记--随机数

    #第一步引入模块 import random #第二步生成随机数 print random.randint(1,3);#[1,2,3]注意这里是闭区间.

  5. [Leetcode][Python]31: Next Permutation

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 31: Next Permutationhttps://oj.leetcode ...

  6. 【POJ】3009 Curling 2.0 ——DFS

    Curling 2.0 Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11432   Accepted: 4831 Desc ...

  7. c++基础 之 面向对象特征一 : 继承

    class Base { public: void f() { cout<<"void f()"<<endl<<endl; } void f(i ...

  8. [置顶] Guava学习之Splitter

    Splitter:在Guava官方的解释为:Extracts non-overlapping substrings from an input string, typically by recogni ...

  9. TabHost 简单用法

    package com.google.tabhost;    import android.app.TabActivity;  import android.os.Bundle;  import an ...

  10. css3 动画(animation)-简单入门

    css3之动画(animation) css3中我们可以使用动画,由于取代以前的gif图片,flash动画,以及部分javascript代码(相信有很多同学都用过jquery中的animate方法来做 ...