- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
项目:我有一个包含 ComboBox 和 FlowLayoutPanel 的父面板。 FlowLayoutPanel 包含数量可变的子面板(继承自 UserControl 的自定义控件)。每个子面板包含一些标签、两个 ComboBox、一个按钮和一个具有 3 个 ComboBox 列和一个按钮列的 DataGridView。 DataGridView 可能有 1-6 行。当从父面板上的 ComboBox 中选择一个项目时,FlowLayoutPanel 会填充子面板。
问题:用大约 50 个子面板填充 FlowLayoutPanel 大约需要 2.5 秒。具体来说,我确定对 FlowLayoutPanel.Controls.AddRange() 的调用是罪魁祸首。
相关代码:我不能在这里发布我的所有代码(太多的代码加上部分代码是 secret 的),但我会尽力解释发生了什么。
家长面板:
private void displayInformation(Suite suite)
{
this.SuspendLayout();
// Get dependencies.
List<SuiteRange> dependents = new List<SuiteRange>(suite.dependencies.Keys);
dependents.Sort(SuiteRange.Compare);
// Create a ChildPanel for each dependent.
List<ChildPanel> rangePanels = new List<ChildPanel>();
foreach (SuiteRange dependent in dependents)
{
ChildPanel sdp = new ChildPanel();
sdp.initialize(initialSuite.name, dataAccess);
sdp.displayInformation(dependent, suite.dependencies[dependent]);
rangePanels.Add(sdp);
}
// Put the child panels in the FlowLayoutPanel.
flpDependencyGroups.SuspendLayout();
// Takes ~2.5 seconds
flpDependencyGroups.Controls.AddRange(rangePanels.ToArray());
flpDependencyGroups.ResumeLayout();
// Takes ~0.5 seconds
updateChildPanelSizes();
this.ResumeLayout();
}
我尝试过的事情:
可能相关的内容:
编辑:解决方案:
@HighCore 的回答是正确的解决方案。不幸的是,我现在不会实现它(它可能会在未来发生),因为我找到了解决方法。解决方法并没有真正解决问题,只是掩盖了它,因此我没有将其作为答案发布。我发现如果“依赖项”选项卡不在顶部(即选择了“产品列表”选项卡),表单加载时间会缩短一半。这将加载时间减少到大约 1 秒,这是可以接受的。当正在加载数据并且“依赖项”选项卡位于顶部时,我切换到“产品列表”选项卡,在选项卡控件上方抛出一个深灰色框,中间显示“正在加载...”,加载数据,然后切换返回依赖项选项卡。
感谢大家的意见和建议,非常感谢。
最佳答案
发布此答案是因为 OP 要求:
这就是您在 WPF 中执行类似操作的方式:
<UserControl x:Class="WpfApplication7.ListBoxSample"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<DockPanel>
<Button Content="Load" Click="Load_Click" DockPanel.Dock="Top"/>
<ListBox ItemsSource="{Binding}"
HorizontalContentAlignment="Stretch">
<ListBox.ItemTemplate>
<DataTemplate>
<Border BorderBrush="LightGray" BorderThickness="1" Padding="5"
Background="#FFFAFAFA">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition/>
<ColumnDefinition/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<TextBlock Text="Dependent Versions" FontWeight="Bold"
Grid.ColumnSpan="2" HorizontalAlignment="Center"/>
<TextBlock Text="From:" FontWeight="Bold"
Grid.Row="1" HorizontalAlignment="Center"/>
<TextBlock Text="To (exclusive):" FontWeight="Bold"
Grid.Row="1" Grid.Column="1" HorizontalAlignment="Center"/>
<ComboBox SelectedItem="{Binding From}"
ItemsSource="{Binding FromOptions}"
Grid.Row="2" Margin="5"/>
<ComboBox SelectedItem="{Binding To}"
ItemsSource="{Binding ToOptions}"
Grid.Row="2" Grid.Column="1" Margin="5"/>
<DataGrid ItemsSource="{Binding ChildItems}"
AutoGenerateColumns="False" CanUserAddRows="False"
Grid.Column="2" Grid.RowSpan="4">
<DataGrid.Columns>
<DataGridTextColumn Header="XXXX" Binding="{Binding XXXX}"/>
<DataGridTextColumn Header="Dependee From" Binding="{Binding DependeeFrom}"/>
<DataGridTextColumn Header="Dependee To" Binding="{Binding DependeeTo}"/>
<DataGridTemplateColumn Width="25">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<Button Content="X"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
<Button Content="Delete"
Grid.Column="3"
HorizontalAlignment="Right" VerticalAlignment="Top"/>
</Grid>
</Border>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</DockPanel>
</UserControl>
代码隐藏(仅支持示例的样板)
public partial class ListBoxSample : UserControl
{
public ListBoxSample()
{
InitializeComponent();
}
public void LoadData()
{
Task.Factory.StartNew(() =>
{
var list = new List<DataItem>();
for (int i = 0; i < 100000; i++)
{
var item = new DataItem()
{
From = "1",
To = "2",
ChildItems =
{
new ChildItem()
{
DependeeFrom = i.ToString(),
DependeeTo = (i + 10).ToString(),
XXXX = "XXXX"
},
new ChildItem()
{
DependeeFrom = i.ToString(),
DependeeTo = (i + 10).ToString(),
XXXX = "XXXX"
},
new ChildItem()
{
DependeeFrom = i.ToString(),
DependeeTo = (i + 10).ToString(),
XXXX = "XXXX"
}
}
};
list.Add(item);
}
return list;
}).ContinueWith(t =>
{
Dispatcher.Invoke((Action) (() => DataContext = t.Result));
});
}
private void Load_Click(object sender, System.Windows.RoutedEventArgs e)
{
LoadData();
}
}
数据项:
public class DataItem
{
public List<ChildItem> ChildItems { get; set; }
public List<string> FromOptions { get; set; }
public List<string> ToOptions { get; set; }
public string From { get; set; }
public string To { get; set; }
public DataItem()
{
ChildItems = new List<ChildItem>();
FromOptions = Enumerable.Range(0,10).Select(x => x.ToString()).ToList();
ToOptions = Enumerable.Range(0, 10).Select(x => x.ToString()).ToList();
}
}
public class ChildItem
{
public string XXXX { get; set; }
public string DependeeFrom { get; set; }
public string DependeeTo { get; set; }
}
然后使用 ElementHost
将其放入现有的 winforms UI 中:
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
var elementHost = new ElementHost
{
Dock = DockStyle.Fill,
Child = new ListBoxSample()
};
Controls.Add(elementHost);
}
}
结果:
DataGrid
延伸到剩余空间来进一步自定义它。参见 WPF Layouts .PresentationCore.dll
、PresentationFramework.dll
、WindowsBase.dll
、System.Xaml.dll
和 WindowsFormsIntegration.dll
,所有这些都属于 .Net Framework 本身(没有第 3 方)关于c# - Control.AddRange(...) 很慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22922233/
我在家里的电脑上玩 Entity Framework 6,决定尝试插入相当多的行,大约 430k。 我的第一次尝试是这样的,是的,我知道它可以做得更好,但无论如何都是为了研究: var watch =
这个问题在这里已经有了答案: Nested object initializer syntax (1 个回答) 关闭 5 年前。 有一个 C# 功能,我不知道它的术语,因此无法找到关于它的文档。 允
我有一些遗留的 C# 代码,其中包含以下部分: private List mList = new List(); public List getList() { List list = new
通用列表中是否有内置函数可以从特定索引中的另一个列表中添加范围,还是我必须自己编写? 例如: List list1 = new List(); List list2 = new List(); lis
在下面的代码中: var cats = new List() {"cat1", "cat2"}; var dogs = new List() {"dog1", "dog2"}; var animals
具有讽刺意味的是,在将一堆旧 Arraylist 转换为使用通用 List(Of foo) 集合时,为了提高类型安全性,我在 List.AddRange() 中遇到了意外行为方法。 鉴于以下代码,我预
项目:我有一个包含 ComboBox 和 FlowLayoutPanel 的父面板。 FlowLayoutPanel 包含数量可变的子面板(继承自 UserControl 的自定义控件)。每个子面板包
我正在为 ObservableCollection 编写一个扩展方法,并且已了解到 .Add 函数每次调用都会引发 3 个属性更改事件, 所以这样的事情是一个坏主意: public static vo
这个问题在这里已经有了答案: Selection.addRange() is deprecated and will be removed from Chrome (1 个回答) 关闭 5 年前。
基本上我正在寻找这样的东西...... cbo_Genre.Items.AddRange({"Horror", "Comedy"}); 最佳答案 看看这个。 ComboBox1.Items.AddRa
如果我有这两个类: class A {} class B : A {} 我制作了一个 List 但我想通过调用 List.AddRange(List) 添加一个 List 但编译器拒绝: Argume
比如说,我有 3 个列表 List l1 List l1,l2,l3 所有 3 个列表都有很多项目我想将它们全部添加到一个列表中 List finalList finalList.AddRange(l
我坚信 ToolStripItemCollection.AddRange 的实现是一个错误: 我制作了带有两个菜单的 Windows 窗体应用程序,每个菜单包含 2 个项目。 first menu s
此问题中的代码生成以下 JSON。 代码应该根据 .Where(a => a.Values != null) 行排除空的“子”键,但它不起作用。 我可以在哪里放置 where 子句,以便 JSON 不
在HttpWebRequest 的AddRange 方法中,我们可以指定要下载的字节范围。我想知道的是如何指定从某个偏移量到文件末尾的范围。 比如如果我们不知道文件的长度,我们可以在Request H
我已经安装了 Connector/NET 6.5.4。在 VisualStutio 中,IntelliSense 建议使用一种名为 MySqlParameterCollection.AddRange
这似乎是一个简单的问题,但对我来说不是,而且搜索也没有结果。到目前为止,我唯一完成的 .net 编程是使用 Delphi Prism。使用 Prism,我可以执行以下操作: var l := new
“源数组不够长。检查 srcIndex 和长度,以及数组的下限。” 我在创建目标列表(在我添加对象的地方)和源列表(从我在目标列表中添加对象的地方)时没有提到任何大小 这是我正在做的类似代码。 Lis
namespace SubscriptionWebsite.PlaceHolders { public class TreeData { public int ID {
我想做的是 FreezableCollection.AddRange(collectionToAdd) 每次我添加到 FreezableCollection 时都会引发一个事件并发生一些事情。现在我有
我是一名优秀的程序员,十分优秀!