WPF TreeView IsExpanded 绑定不上的问题
最近项目上需要通过MVVM来控制TreeView,其中需要需要控制通过搜索来定位某个节点,正常逻辑下,首先通过需要在树上面找到该节点,然后选中该节点,并将该节点的父节点展开,这个时候需要通过MVVM来控制,需要绑定起来,只是一直没有binding上,代码如下:
MVVM示例代码:
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace DragDrop
{
class DataItem : NotifyPropertyBase, ICloneable
{
public DataItem(string header, int deepth = )
{
Header = header;
Deepth = deepth;
} public object Clone()
{
DataItem dataItem = new DataItem(Header, Deepth);
dataItem.IsExpanded = IsExpanded;
dataItem.IsSelected = IsSelected;
dataItem.Deepth = Deepth;
foreach (DataItem item in Items)
dataItem.Items.Add((DataItem)item.Clone());
return dataItem;
} private string header;
public string Header
{
get { return header; }
set
{
SetProperty(ref header, value);
}
} private bool isSelected;
public bool IsSelected
{
get { return isSelected; }
set { SetProperty(ref isSelected, value); }
} private bool isExpanded;
public bool IsExpanded
{
get { return isExpanded; }
set
{
SetProperty(ref isExpanded, value);
Console.WriteLine("{0}--{1}", Header, IsExpanded);
}
} private int deepth;
public int Deepth
{
get { return deepth; }
set
{
if (deepth != value)
{
deepth = value;
SetProperty(ref deepth, value);
}
}
} private ObservableCollection<DataItem> mItems = null;
public ObservableCollection<DataItem> Items
{
get
{
if (mItems == null)
mItems = new ObservableCollection<DataItem>();
return mItems;
}
} } class Data
{
private static Data mInstance = new Data(); public static Data Instance
{
get { return mInstance; }
} private ObservableCollection<DataItem> GenerateTreeViewItems()
{
ObservableCollection<DataItem> items = new ObservableCollection<DataItem>(); DataItem item1 = new DataItem("TreeViewItem1");
item1.Items.Add(new DataItem("SubItem1", item1.Deepth));
item1.Items.Add(new DataItem("SubItem2", item1.Deepth));
item1.Items.Add(new DataItem("SubItem3", item1.Deepth));
item1.Items.Add(new DataItem("SubItem4", item1.Deepth));
items.Add(item1); DataItem item2 = new DataItem("TreeViewItem2");
item2.Items.Add(new DataItem("SubItem1", item2.Deepth));
item2.Items.Add(new DataItem("SubItem2", item2.Deepth));
items.Add(item2); DataItem item3 = new DataItem("TreeViewItem3");
item3.Items.Add(new DataItem("SubItem1", item3.Deepth));
item3.Items.Add(new DataItem("SubItem2", item3.Deepth));
item3.Items.Add(new DataItem("SubItem3", item3.Deepth));
item3.Items.Add(new DataItem("SubItem4", item3.Deepth));
item3.Items.Add(new DataItem("SubItem5", item3.Deepth));
item3.Items.Add(new DataItem("SubItem6", item3.Deepth));
item3.Items.Add(new DataItem("SubItem7", item3.Deepth));
item3.Items.Add(new DataItem("SubItem8", item3.Deepth));
items.Add(item3); return items;
} private ObservableCollection<DataItem> GenerateListItems()
{
ObservableCollection<DataItem> items = new ObservableCollection<DataItem>();
items.Add(new DataItem("ListBoxItem1"));
items.Add(new DataItem("ListBoxItem2"));
items.Add(new DataItem("ListBoxItem3"));
items.Add(new DataItem("ListBoxItem4"));
items.Add(new DataItem("ListBoxItem5"));
return items;
} public ObservableCollection<DataItem> TreeViewItems
{
get
{
if (mTreeViewItems == null)
mTreeViewItems = GenerateTreeViewItems();
return mTreeViewItems;
}
} public ObservableCollection<DataItem> ListBoxItems
{
get
{
if (mListBoxItems == null)
mListBoxItems = GenerateListItems();
return mListBoxItems;
}
} private ObservableCollection<DataItem> mTreeViewItems = null;
private ObservableCollection<DataItem> mListBoxItems = null;
}
}
界面代码:
<Window x:Class="DragDrop.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:DragDrop"
mc:Ignorable="d"
Title="MainWindow" Height="" Width="">
<Window.Resources>
<HierarchicalDataTemplate x:Key="treeViewTemplate" DataType="{x:Type local:DataItem}" ItemsSource="{Binding Items}">
<TextBlock Text="{Binding Header}"/>
</HierarchicalDataTemplate> <Style x:Key="TreeViewStyle" TargetType="{x:Type TreeViewItem}">
<Setter Property="IsSelected" Value="{Binding IsSelected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
<Setter Property="IsExpanded" Value="{Binding IsExpanded, Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"/>
<Style.Triggers>
<DataTrigger Binding="{Binding Deepth}" Value="">
<Setter Property="IsExpanded" Value="True"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid x:Name="mTopLevelGrid">
<TreeView x:Name="mTreeView" Grid.Column=""
ItemsSource="{Binding Source={x:Static local:Data.Instance}, Path=TreeViewItems}"
ItemTemplate="{StaticResource treeViewTemplate}"
ItemContainerStyle="{StaticResource TreeViewStyle}"/>
</Grid>
</Window>
数据的绑定没有问题,界面没有问题,奇怪的是IsSelected可以正常绑定,但是IsExpanded就是不行,后来发现这两个属性唯一的区别就是在TreeView的式样中
<Style.Triggers>
<DataTrigger Binding="{Binding Deepth}" Value="">
<Setter Property="IsExpanded" Value="True"/>
</DataTrigger>
</Style.Triggers>
后面把这个DataTrigger这段代码注释掉,编译一下,重新运行,IsExpanded就可以正常绑定。后面自己思考了一下,MVVM模式实现将ViewModel与界面上面的显示绑定起来,实际上也就是使用了观察者模式,而Trigger的原理应该和数据binding是一样的,而且这个Trigger写在后面,可能直接把前面的绑定取代了,但是试了一下,将DataTrigger放到前面,也还是绑定不上,这种可能性排除;个人猜测可能是Trigger的优先级比较高,从而造成IsExpanded一直Binding不上去。
WPF TreeView IsExpanded 绑定不上的问题的更多相关文章
- 2019-11-29-WPF-笔刷绑定不上可能的原因
原文:2019-11-29-WPF-笔刷绑定不上可能的原因 title author date CreateTime categories WPF 笔刷绑定不上可能的原因 lindexi 2019-1 ...
- 2019-11-29-WPF-依赖属性绑定不上调试方法
原文:2019-11-29-WPF-依赖属性绑定不上调试方法 title author date CreateTime categories WPF 依赖属性绑定不上调试方法 lindexi 2019 ...
- 2019-8-2-WPF-依赖属性绑定不上调试方法
title author date CreateTime categories WPF 依赖属性绑定不上调试方法 lindexi 2019-08-02 19:56:32 +0800 2019-8-2 ...
- 2019-9-18-WPF-笔刷绑定不上可能的原因
title author date CreateTime categories WPF 笔刷绑定不上可能的原因 lindexi 2019-09-18 09:46:14 +0800 2019-9-18 ...
- WPF使用附加属性绑定,解决data grid列绑定不上的问题
背景 需要对datagrid的列header添加自定义属性,然后绑定,并根据不同的列header绑定不同的值,传统的加扩展类太麻烦,而附加属性的特点更适用于这种场景. 1.xaml 代码 <Da ...
- 【WPF】给TextBox添上Label
原文:[WPF]给TextBox添上Label 引言 在客户端开发中,要说出现频率大的控件,必定有TextBox的身影.然而在TextBox的旁边通常得有个基友Label,形影不离.为此,我们 ...
- WPF TreeView HierarchicalDataTemplate
原文 WPF TreeView HierarchicalDataTemplate HierarchicalDataTemplate 的DataType是本层的绑定,而ItemsSource是绑定下层的 ...
- WPF TreeView Indent 减少节点的缩进
www.swack.cn - 原文链接:WPF TreeView Indent 减少节点的缩进 问题 最近一个需求,需要在界面中实现Windows资源管理器TreeView的界面.但是我发现,我做出的 ...
- 已超过传入消息(65536)的最大消息大小配额。若要增加配额,请使用相应绑定元素上的 MaxReceivedMessageSize 属性。
错误:已超过传入消息(65536)的最大消息大小配额.若要增加配额,请使用相应绑定元素上的 MaxReceivedMessageSize 属性. 或者 错误:反序列化操作“GetAllUserData ...
随机推荐
- 生活类App原型制作分享-AnyList
AnyList是一款可以帮你创建购物清单,并且帮助你整理食谱的生活工具App,前面引导页采用图片+文字的方式,介绍App的用法,登录注册采用选项卡切换的方式,减少了页面切换的繁琐操作,在Mockplu ...
- jQuery加载完成事件 $(function(){ })的全局异常拦截
通常我们在页面加载完成的时候要写入一些功能脚本,如: $(function(){/*脚本 - 1*/ console.log('start'); }) $(function(){/*脚本 - 2*/ ...
- 【RabbitMQ】 RabbitMQ安装
MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们.消息传递指的是程序之间 ...
- 求先序排列(NOIP2001&NOIP水题测试(2017082301))
题目链接:求先序排列 这道题讲白了,就是数的构造,然后遍历. 思路大致是这样: 我们先通过后序遍历,找到当前区间的根,然后在中序遍历中找到根对应的下标,然后就可以分出左右子树,建立当前根与左右子树根的 ...
- 48.UIButton上的字体居右对齐
UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom]; button.titleLabel.textAlignment = NSTe ...
- web-Amazon
一 准备实验数据 1.1.下载数据 wget http://snap.stanford.edu/data/amazon/all.txt.gz 1.2.数据分析 1.2.1.数据格式 product/p ...
- Linux---CentOS 定时运行脚本配置
很多时候我们有希望服务器定时去运行一个脚本来触发一个操作,比如使用七牛的工具上传,如果同步文件里面有新增加一个文件,这个时候我们可以提供定时脚本去完成我们需要的同步命令(七牛的qrsbox工具是自动会 ...
- 2018.11.07 NOIP训练 lzy的游戏(01背包)
传送门 考虑对于每次最后全部选完之后剩下的牌的集合都对应着一种构造方法. 一个更接地气的说法: 设消耗的牌数为ttt,如果使用的牌的lll值之和也为ttt,则对应着一种构造方式让这种情形成立. 于是做 ...
- 2018.11.03 NOIP模拟 树(长链剖分优化dp)
传送门 考虑直接推式子不用优化怎么做. 显然每一个二进制位分开计算贡献就行. 即记录fi,jf_{i,j}fi,j表示距离iii这个点不超过jjj的点的每个二进制位的0/10/10/1个数. 但直接 ...
- warning: this decimal constant is unsigned only in ISO C90问题的处理及理解
参考:https://blog.csdn.net/duguduchong/article/details/7709482 https://bbs.csdn.net/topics/391892978?p ...