WPF DataGrid与ListView性能对比与场景选择
开门见山的说

性能对比:
在Demo中,DataGrid与ListView默认开启虚拟化(可以理解为动态渲染,类似懒加载只渲染屏幕可以看见的地方)
DataGrid渲染10列50行随机字符280ms
ListView渲染10列50行随机字符80ms
场景选择:
ListView只生成需要展示的数据类型的控件,渲染相对DataGrid要快很多
DataGrid会生成编辑两种状态单元格(编辑与非编辑),如非必要不推荐使用(编辑单元格WPF硬伤/(ㄒoㄒ)/~~)
UI效果图:

Code:
XAML
<Window x:Class="WPFDemo.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:WPFDemo" mc:Ignorable="d" Title="MainWindow" Height="450" Width="800">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="40" />
<RowDefinition />
</Grid.RowDefinitions>
<WrapPanel VerticalAlignment="Center" HorizontalAlignment="Center">
<Button Margin="5,0" Width="80" Content="Next" Click="Button_Click"></Button>
<Label Content="DataGrid" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0" Content="{Binding DgMs,UpdateSourceTrigger=PropertyChanged,Mode=TwoWay}" x:Name="uiDgMs"></Label>
<Label Content="ms" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0,0,0" Content="ListView" Style="{x:Null}" VerticalAlignment="Center"></Label>
<Label Margin="5,0" Content="{Binding LvMs,UpdateSourceTrigger=PropertyChanged,Mode=TwoWay}" x:Name="uiLvMs"></Label>
<Label Content="ms" Style="{x:Null}" VerticalAlignment="Center"></Label>
</WrapPanel>
<TabControl Grid.Row="1">
<TabItem Header="DataGrid">
<DataGrid ItemsSource="{Binding DgList}" RowStyle="{x:Null}" AutoGenerateColumns="False" EnableColumnVirtualization="True" EnableRowVirtualization="True">
<DataGrid.Resources>
<Style TargetType="DataGridRow">
<Setter Property="Height" Value="24" />
</Style>
</DataGrid.Resources>
<DataGrid.Columns>
<DataGridTextColumn Header="F1" Binding="{Binding F1}"></DataGridTextColumn>
<DataGridTextColumn Header="F2" Binding="{Binding F2}"></DataGridTextColumn>
<DataGridTextColumn Header="F3" Binding="{Binding F3}"></DataGridTextColumn>
<DataGridTextColumn Header="F4" Binding="{Binding F4}"></DataGridTextColumn>
<DataGridTextColumn Header="F5" Binding="{Binding F5}"></DataGridTextColumn>
<DataGridTextColumn Header="F6" Binding="{Binding F6}"></DataGridTextColumn>
<DataGridTextColumn Header="F7" Binding="{Binding F7}"></DataGridTextColumn>
<DataGridTextColumn Header="F8" Binding="{Binding F8}"></DataGridTextColumn>
<DataGridTextColumn Header="F9" Binding="{Binding F9}"></DataGridTextColumn>
<DataGridTextColumn Header="F10" Binding="{Binding F10}"></DataGridTextColumn>
</DataGrid.Columns>
</DataGrid>
</TabItem>
<TabItem Header="ListView">
<ListView ItemsSource="{Binding LvList}">
<ListView.ItemContainerStyle>
<Style TargetType="ListViewItem">
<Setter Property="Height" Value="20" />
</Style>
</ListView.ItemContainerStyle>
<ListView.View>
<GridView>
<GridViewColumn Header="F1" DisplayMemberBinding="{Binding F1}"></GridViewColumn>
<GridViewColumn Header="F2" DisplayMemberBinding="{Binding F2}"></GridViewColumn>
<GridViewColumn Header="F3" DisplayMemberBinding="{Binding F3}"></GridViewColumn>
<GridViewColumn Header="F4" DisplayMemberBinding="{Binding F4}"></GridViewColumn>
<GridViewColumn Header="F5" DisplayMemberBinding="{Binding F5}"></GridViewColumn>
<GridViewColumn Header="F6" DisplayMemberBinding="{Binding F6}"></GridViewColumn>
<GridViewColumn Header="F7" DisplayMemberBinding="{Binding F7}"></GridViewColumn>
<GridViewColumn Header="F8" DisplayMemberBinding="{Binding F8}"></GridViewColumn>
<GridViewColumn Header="F9" DisplayMemberBinding="{Binding F9}"></GridViewColumn>
<GridViewColumn Header="F10" DisplayMemberBinding="{Binding F10}"></GridViewColumn>
</GridView>
</ListView.View>
</ListView>
</TabItem>
</TabControl>
</Grid>
</Window>
后台
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Windows; namespace WPFDemo
{
/// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
view = new MainWindowView();
view.DgList = new System.Collections.ObjectModel.ObservableCollection<DgModel>();
this.DataContext = view;
InitData();
}
MainWindowView view;
private void InitData()
{
var list = new List<DgModel>();
Random rd = new Random();
for (int i = 0; i < 50; i++)
{
var item = new DgModel();
item.F1 = rd.Next().ToString();
item.F2 = rd.Next().ToString();
item.F3 = rd.Next().ToString();
item.F4 = rd.Next().ToString();
item.F5 = rd.Next().ToString();
item.F6 = rd.Next().ToString();
item.F7 = rd.Next().ToString();
item.F8 = rd.Next().ToString();
item.F9 = rd.Next().ToString();
item.F10 = rd.Next().ToString();
list.Add(item);
}
Stopwatch ms = new Stopwatch();
ms.Restart();
view.DgList = new System.Collections.ObjectModel.ObservableCollection<DgModel>(list);
ms.Stop();
view.DgMs = ms.ElapsedMilliseconds.ToString();
ms.Restart();
view.LvList = new System.Collections.ObjectModel.ObservableCollection<DgModel>(list);
ms.Stop();
view.LvMs = ms.ElapsedMilliseconds.ToString();
}
private void Button_Click(object sender, RoutedEventArgs e)
{
InitData();
}
}
}
相关回答:
ListView和ListBox的区别?(ListView是数据表格,ListBox是类似Tree的单选列表)
博主使用的是第三方开源控件HandyControl(强烈安利)
博客园空间不足,Demo加群下载
WPF DataGrid与ListView性能对比与场景选择的更多相关文章
- WPF DataGrid、ListView 简单绑定
DataGrid运行效果: xaml 代码: DataGridName= dtgData ItemsSource= {Binding} AutoGenerateColumns= False DataG ...
- 不同Framework下StringBuilder和String的性能对比,及不同Framework性能比(附Demo)
本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 环境搭建 测试用例 MSDN说明 ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析
最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...
- java中常见的json解析方法、库以及性能对比
常见的json解析有原生的JSONObject和JSONArray方法,谷歌的GSON库,阿里的fastjson,还有jackson,json-lib. Gson(项目地址:https://githu ...
- [原] KVM 环境下MySQL性能对比
KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...
- 【腾讯Bugly干货分享】跨平台 ListView 性能优化
本文来自于腾讯Bugly公众号(weixinBugly),未经作者同意,请勿转载,原文地址:https://mp.weixin.qq.com/s/FbiSLPxFdGqJ00WgpJ94yw 导语 精 ...
- Android之ListView性能优化——一行代码绑定数据——万能适配器
如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...
- 浅谈C++之冒泡排序、希尔排序、快速排序、插入排序、堆排序、基数排序性能对比分析之后续补充说明(有图有真相)
如果你觉得我的有些话有点唐突,你不理解可以想看看前一篇<C++之冒泡排序.希尔排序.快速排序.插入排序.堆排序.基数排序性能对比分析>. 这几天闲着没事就写了一篇<C++之冒泡排序. ...
- Java--Stream,NIO ByteBuffer,NIO MappedByteBuffer性能对比
目前Java中最IO有多种文件读取的方法,本文章对比Stream,NIO ByteBuffer,NIO MappedByteBuffer的性能,让我们知道到底怎么能写出性能高的文件读取代码. pack ...
随机推荐
- 小程序image无法显示图片
图片路径中有中文 图片地址为http开头,图片只能在调试模式中显示,真机也必须开调试. 图片名称有空格 图片的后缀必须为小写的.png或者.jpg
- Newbe.ObjectVisitor 0.4.4 发布,模型验证器上线
Newbe.Claptrap 0.4.4 发布,模型验证器上线. 更新内容 完全基于表达式树的模型验证器 本版本,我们带来了基于表达式树实现的模型验证器.并实现了很多内置的验证方法. 我们罗列了与 F ...
- 关于VS.Net应用的图标提取方法
.Net的资源文件 VS.Net 支持三种文件类型的resource:.txt..resx..resources. system.resources 名字空间支持三种资源文件: txt 文件,只能有字 ...
- springboot 导出xlsx文件
@Override public String downModelXlsFile(SxSourceReq param, HttpServletResponse response) { //设置响应编码 ...
- NOI Online #2 提高组 游戏
没用二项式反演的菜比. 题目链接 Solution 非平局代表的树上祖先关系是比较好统计,(可以在处理一个点时,考虑用他去匹配他的子树中的东西)而平局的关系比较难统计.我们不妨求出至少 \(k\) 个 ...
- springboot配置ssl证书
springboot默认使用的是tomcat: 1.先到阿里云上注册一个证书,绑定域名:后面可以在管理中下载证书,下载tomcat对应的证书(一个*.pfx文件和*.txt文件) 2.将pfx文件拷贝 ...
- 如何写好PPT,什么样的PPT容易被人理解记住
PPT一般是用于讲解性的行为而存在,那如果写好PPT呢?如果写好,这个完全要取决于你所面向的目标读者,是用于学术行为呢?还是用于商业行为.面对不同的目标群体,有不同的策略.但是无论面向群体是谁我们都有 ...
- STL——容器(List)List 的数据元素插入和删除操作
push_back(elem); //在容器尾部加入一个元素 1 #include <iostream> 2 #include <list> 3 4 using namespa ...
- 恋爱话术库撩妹至尊VIP版
本软件来自互联网,解锁永久至尊VIP 是一款教你撩妹密语软件.和女生聊天没有话题? 不知道怎么逗乐女生? 女生生气了不会哄? 不知道怎么让女生愿意跟你聊下去? 不知道女生对你有没有意思? 遇到不知道怎 ...
- 目前市面上比较流行的devops运维平台汇总
1,spug 1,Spug简介 Spug是面向中小型企业设计的无 Agent的自动化运维平台,整合了主机管理.主机批量执行.主机在线终端.应用发布.任务计划.配置中心.监控.报警等一系列功能.演示地址 ...