C#Form.show()错误System.InvalidOperationException

时间:2016-04-28 22:24:14

标签: c# forms fill

我正在尝试使用类列表填充三个ComboBox,但它出错:

  

未处理的类型' System.InvalidOperationException'发生在System.Windows.Forms.dll

中      

" System.InvalidOperationException:在调整自动填充列时无法执行此操作"

偶尔会发生此错误,但永远不会发生。

这一点指向form.Show();

代码:

 Catalogo form = new Catalogo();
 form.Show();

这是代码的形式:

private void btSair_Click(object sender, EventArgs e)
{
    DialogResult var;
    var = MessageBox.Show("Deseja fechar esta janela ? ", "", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
    if (var == DialogResult.Yes)
    {
        GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);
        this.Close();   
    }
}

private void Catalogo_Load(object sender, EventArgs e)
{
    cliente = new KEYSERVICEClient();
    List<Catalogo> asdf = new List<Catalogo>();

    var listar = cliente.FillCombosCatalogo(Global.Id_empresa);

    for (int i = 0; i < listar.Count; i++)
    {
        cbFabricante.Items.Add(listar[i].fabricante);
        cbModelo.Items.Add(listar[i].modelo);
        cbNumera.Items.Add(listar[i].numeracao);
    }
}

FillComboCatalogo方法:

public List<CatalogoItens> FillCombosCatalogo(int id_empresa)
{
    SqlDataReader objReader;
    SqlCommand objcmd = null;

    vsql = "SELECT [ID_EMPRESA], [MODELO], [FABRICANTE],[NUMERACAO] As Identificador,[MODELO],[FABRICANTE], [NUMERACAO] FROM PRODUTOS_CHAVES WHERE @ID_EMPRESA = ID_EMPRESA";

    List<CatalogoItens> catag = new List<CatalogoItens>();

    if (this.Conectar())
    {
        try
        {
            objcmd = new SqlCommand(vsql, objCon);

            objcmd.Parameters.Add(new SqlParameter("@ID_EMPRESA", id_empresa));

            objReader = objcmd.ExecuteReader();

            while (objReader.Read())
            {
                CatalogoItens catalogo = new CatalogoItens()
                {
                    modelo = (objReader.GetString(1)),
                    fabricante = (objReader.GetString(2)),
                    numeracao = (objReader.GetString(3))
                };
                catag.Add(catalogo);
            }
                return catag;
        }
        catch
        {

        }
        finally
        {
            this.Desconectar();
        }
    }
    return null;
}

1 个答案:

答案 0 :(得分:0)

如果你想更改组合框项目,并添加大量项目(在循环中),请始终使用Suspend / ResumeLayout。

例如:

cbFabricante.SuspendLayout();
cbModelo.SuspendLayout();
cbNumera.SuspendLayout();
for (int i = 0; i < listar.Count; i++)
{
    cbFabricante.Items.Add(listar[i].fabricante);
    cbModelo.Items.Add(listar[i].modelo);
    cbNumera.Items.Add(listar[i].numeracao);
}
cbFabricante.ResumeLayout();
cbModelo.ResumeLayout();
cbNumera.ResumeLayout();

如果您不这样做,系统会在每次添加项目时重新绘制组合框,而不是重新绘制一次 - 添加所有项目后。

这可能是例外的原因。这无济于事,为我们提供您在这些组合框中设置的参数