WPF 模板选择器

该文介绍了如何在WPF中利用自定义的DataTemplateSelector类根据学生考试成绩动态选择显示模板。当成绩高于60分时,显示考的非常好的模板;否则,显示红色背景并提示电话家长警告。这种方法允许根据条件改变UI展示,但应注意过度使用可能影响程序性能。
摘要由CSDN通过智能技术生成

WPF 模板选择器

由于需要提前在程序内定义多套模板,会影响程序性能和开销,所以慎用;

项目结构:

创建一个模板选择类TestDataTemplateSelector:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;

namespace WpfApp2
{
    public class TestDataTemplateSelector: DataTemplateSelector
    {
        public DataTemplate HighTemplate { get; set; }

        public DataTemplate LowTemplate { get; set; }

        public override DataTemplate SelectTemplate(object item, DependencyObject container)
        {
            var stu = (Student)item;
            if (stu.Result > 60)
                return HighTemplate;
            else
                return LowTemplate;
        }
    }
}

MainWindow.xaml代码:

在Window.Resources中定义了两个模板HighTemplate和LowTemplate。

<Window x:Class="WpfApp2.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:WpfApp2"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Window.Resources>
        <DataTemplate x:Key="HighTemplate">
            <StackPanel>
                <TextBlock Text="{Binding Name}"/>
                <TextBlock Text="考的非常好!"/>
            </StackPanel>
        </DataTemplate>

        <DataTemplate x:Key="LowTemplate">
            <StackPanel Background="Red">
                <TextBlock Text="{Binding Name}"/>
                <TextBlock Text="电话家长警告!"/>
            </StackPanel>
        </DataTemplate>
    </Window.Resources>
    <Grid>
        <ListBox x:Name="list" ItemsSource="{Binding Model}">
            <ListBox.ItemTemplateSelector>
                <local:TestDataTemplateSelector HighTemplate="{StaticResource HighTemplate}" LowTemplate="{StaticResource LowTemplate}"/>
            </ListBox.ItemTemplateSelector>
        </ListBox>
    </Grid>
</Window>

MainWindow.xaml.cs代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace WpfApp2
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();

            List<Student> stuList = new List<Student>();
            stuList.Add(new Student() { Name = "A", Result = 40 });
            stuList.Add(new Student() { Name = "B", Result = 50 });
            stuList.Add(new Student() { Name = "C", Result = 60 });
            stuList.Add(new Student() { Name = "D", Result = 70 });
            stuList.Add(new Student() { Name = "E", Result = 80 });

            list.DataContext = new { Model = stuList};
        }
    }


    public class Student
    {
        public string Name { get; set; }
        public int Result { get; set; }
    }
}

运行结果:

根据学生成绩结果来选择不同的模板展示数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值