背景 有两个组合框仅在Sorted属性中有所不同。 comboBox1的Sorted属性设置为 true ,comboBox2的Sorted属性设置为 false 。尝试重新分配/重置这两个组合框的数据源属性时,comboBox1不显示数据,comboBox2显示。为什么Sorted属性会阻止comboBox1正确显示其数据?
以下所有代码:
public partial class Form1 : Form
{
private string[] a8BitGames = { "Metroid", "Zelda", "Phantasy Star", "SB:S&SEP" };
private string[] a16BitGames = { "StarFox", "Link", "Final Fantasy", "Altered Beast" };
private List<string> lSomeList = null;
private List<string> lSomeOtherList = null;
public Form1()
{
InitializeComponent();
this.lSomeList = new List<string>(a8BitGames);
this.lSomeOtherList = new List<string>(a16BitGames);
this.comboBox1.DataSource = lSomeList;
this.comboBox2.DataSource = lSomeOtherList;
}
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
this.IndexChanged(1);
}
private void IndexChanged(int comboBox)
{
this.comboBox1.DataSource = null;
this.comboBox1.DataSource = a16BitGames;
this.comboBox2.DataSource = null;
this.comboBox2.DataSource = a8BitGames;
}
private void comboBox2_SelectedIndexChanged(object sender, EventArgs e)
{
this.IndexChanged(2);
}
}
partial class Form1
{
/// <summary>
/// Required designer variable.
/// </summary>
private System.ComponentModel.IContainer components = null;
/// <summary>
/// Clean up any resources being used.
/// </summary>
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Windows Form Designer generated code
/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InitializeComponent()
{
this.comboBox1 = new System.Windows.Forms.ComboBox();
this.comboBox2 = new System.Windows.Forms.ComboBox();
this.SuspendLayout();
//
// comboBox1
//
this.comboBox1.FormattingEnabled = true;
this.comboBox1.Location = new System.Drawing.Point(13, 13);
this.comboBox1.Name = "comboBox1";
this.comboBox1.Size = new System.Drawing.Size(121, 21);
this.comboBox1.Sorted = true;
this.comboBox1.TabIndex = 0;
this.comboBox1.SelectedIndexChanged += new System.EventHandler(this.comboBox1_SelectedIndexChanged);
//
// comboBox2
//
this.comboBox2.FormattingEnabled = true;
this.comboBox2.Location = new System.Drawing.Point(13, 41);
this.comboBox2.Name = "comboBox2";
this.comboBox2.Size = new System.Drawing.Size(121, 21);
this.comboBox2.TabIndex = 1;
this.comboBox2.SelectedIndexChanged += new System.EventHandler(this.comboBox2_SelectedIndexChanged);
//
// Form1
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(284, 262);
this.Controls.Add(this.comboBox2);
this.Controls.Add(this.comboBox1);
this.Name = "Form1";
this.Text = "Form1";
this.ResumeLayout(false);
}
#endregion
private System.Windows.Forms.ComboBox comboBox1;
private System.Windows.Forms.ComboBox comboBox2;
}
答案 0 :(得分:1)
你是否意外隐藏了一个例外?根据MSDN,当“尝试对附加到数据源的ComboBox进行排序时,您将收到”ArgumentException“。
http://msdn.microsoft.com/en-us/library/system.windows.forms.combobox.sorted.aspx
答案 1 :(得分:1)
尝试在设置DataSource
时对列表进行排序 public List<string> A16Games
{
get { return this.a16BitGames.OrderBy(x => x).ToList(); }
}
public List<string> A8Games
{
get { return this.a8BitGames.OrderBy(x => x).ToList(); }
}
this.comboBox1.DataSource = this.A16Games;
this.comboBox2.DataSource = this.A8Games;
答案 2 :(得分:1)
问题是您无法更改已排序的组合框的数据源。 以下是ComboBox控件代码的摘录:
protected override void OnDataSourceChanged(EventArgs e)
{
if ((this.Sorted && (this.DataSource != null)) && base.Created)
{
this.DataSource = null;
throw new InvalidOperationException(System.Windows.Forms.SR.GetString("ComboBoxDataSourceWithSort"));
}
...
...
}
在这种情况下,您应该收到InvalidOperationException。 为什么没有收到? 这是答案:
ComboBox控件中DataSource属性的实现重定向到其基类(ListControl)实现:
public object DataSource
{
get
{
return base.DataSource;
}
set
{
base.DataSource = value;
}
}
然后在基类的DataSource中:
public object DataSource
{
[TargetedPatchingOptOut("Performance critical to inline this type of method across NGen image boundaries")]
get
{
return this.dataSource;
}
set
{
if (((value != null) && !(value is IList)) && !(value is IListSource))
{
throw new ArgumentException(System.Windows.Forms.SR.GetString("BadDataSourceForComplexBinding"));
}
if (this.dataSource != value)
{
try
{
this.SetDataConnection(value, this.displayMember, false);
}
catch
{
this.DisplayMember = "";
}
if (value == null)
{
this.DisplayMember = "";
}
}
}
}
请注意沉默的 catch 块。 由于SetDataConnection调用OnDataSourceChanged然后就我的分析是正确的,这就是原因。如果我错了,请纠正我。