• 05. DataTemplate


    参考JusterZhu视频和文档,ppt文档基本全抄

    一、DataTemplate

    在日常开发中,会遇到需要在一个集合控件中通过某个Type属性选择不同的View显示在控件上。那么用常规的绑定是无法完成的,这时候微软提供了一个DataTemplateSelector对象帮助开发者完成此项功能。

    实现步骤:
    1.实现需要绑定的集合,并指定好类型
    2.实现不同的DataTemplate,并实现好里面的样式
    3.基于DataTemplateSelector实现自定义模板选择器
    4.将DataTemplateSelector 、 DataTemplate、List、目标控件关联(绑定)起来。

    
        
            
        
    
        
            
                
                    
                        
                        
                    
                
            
            
                
                    
                        
                        
                            
                        
                    
                
            
            
                
                    
                        
                        
                    
                
            
            
                
                    
                        
                        
                    
                
            
            
        
    
        
            
        
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    internal class DataTypeTemplateSelector: DataTemplateSelector
    {
        public override DataTemplate SelectTemplate(object item, DependencyObject container)
        {
            if (item is MainModel)
            {
                var model = item as MainModel;
                switch (model.Person) 
                {
                    case Person.One:
                        return (container as FrameworkElement).FindResource("OneDataTemplate") as DataTemplate;
                    case Person.Two:
                        return (container as FrameworkElement).FindResource("TwoDataTemplate") as DataTemplate;
                    case Person.Three:
                        return (container as FrameworkElement).FindResource("ThreeDataTemplate") as DataTemplate;
                    case Person.Four:
                        return (container as FrameworkElement).FindResource("FourDataTemplate") as DataTemplate;
                }
            }
    
            return base.SelectTemplate(item, container);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    public enum Person
    {
        One, 
        Two, 
        Three, 
        Four 
    }
    
    internal class MainModel
    {
        public string Name {  get; set; }
        public Person Person { get; set; }
        public string Color {  get; set; } 
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    internal class MainViewModel
    {
        public ObservableCollection mainModels { get; set; }
        public MainViewModel()
        {
            mainModels = new ObservableCollection
            {
                new MainModel { Person = Person.One, Name = "dawa", Color = "Red" },
                new MainModel { Person = Person.Two, Name = "erwa", Color = "Green" },
                new MainModel { Person = Person.Three, Name = "sanwa", Color = "Blue" },
                new MainModel { Person = Person.Four, Name = "siwa", Color = "Yellow" }
            };
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    java面试题之redis篇
    SCHP(CVPR2019)-人体解析论文阅读
    lambda表达式 —— 过滤再排序未生效问题排查
    强化学习(五)基于时序差分法 TD 的求解
    【电路笔记】-电流源
    K8S(九):Pod的重启策略以及健康检查和服务可用性检查
    9月22日上课内容 Docker
    Centos7安装mysql和composer
    【渝偲】DSPE-PEG-Galactose;DSPE-PEG-半乳糖;磷脂聚乙二醇半乳糖 长循环脂质体
    单元测试UnitTest中的数据驱动
  • 原文地址:https://blog.csdn.net/zzyzxb/article/details/134077534