在form_load和button_click中调用函数有什么区别吗?

时间:2016-09-10 03:28:24

标签: c# lifecycle

我通过向datagridview显示数据来完成窗口表单应用程序。但是当datagridview中显示数据时出现了一些问题。

功能:

private void MySQL_ToDatagridview4()
{
    dataGridView3.Columns.Clear();
    mcon.Close();
    mcon.Open();
    MySqlDataAdapter MyDA = new MySqlDataAdapter();
    string sqlSelectAll = "SELECT Item_Name,Item_Pic from stockitem ORDER BY Main_Category_ID ASC, Item_Name ASC";
    MyDA.SelectCommand = new MySqlCommand(sqlSelectAll, mcon);
    DataTable table = new DataTable();
    MyDA.Fill(table);
    BindingSource bSource = new BindingSource();
    bSource.DataSource = table;
    this.dataGridView3.DataSource = bSource;
    DataGridViewImageColumn imageColumn = new DataGridViewImageColumn();
    imageColumn.HeaderText = "Pic";
    dataGridView3.Columns.Insert(0, imageColumn);
    for (int i = 0; i < table.Rows.Count; i++)
    {
        try
        {
            String pic = table.Rows[i]["Item_Pic"].ToString();
            Byte[] bitmapData = Convert.FromBase64String(FixBase64ForImage(pic));
            System.IO.MemoryStream streamBitmap = new System.IO.MemoryStream(bitmapData);
            def = new Bitmap((Bitmap)Image.FromStream(streamBitmap));
        }
        catch (Exception e)
        {
            MessageBox.Show(e.StackTrace);
        }
        dataGridView3.Rows[i].Cells[0].Value = def;
    }
    dataGridView3.Columns.Remove("Item_Pic");
    foreach (DataGridViewRow row in dataGridView3.Rows)
    {
        row.Height = 110;
    }
    foreach (DataGridViewColumn col in dataGridView3.Columns)
    {
        col.Width = 110;
    }

    for (int i = 0; i < dataGridView3.ColumnCount; i++)
    {
        dataGridView3.Columns[i].SortMode = DataGridViewColumnSortMode.NotSortable;
        dataGridView3.AutoResizeColumns();
        dataGridView3.Columns[i].DefaultCellStyle.Font = new System.Drawing.Font("Verdana", 8F, FontStyle.Bold);
    }
    mcon.Close();
}

在Form_Load中调用

private void Form1_Load(object sender, EventArgs e)
{
    MySQL_ToDatagridview4();
}

结果:

RFC 7230 3.1.1

然后当我点击按钮

private void button6_Click(object sender, EventArgs e)
{
    MySQL_ToDatagridview4();
}

结果:

Image

为什么结果如此不同?它调用相同的功能。

1 个答案:

答案 0 :(得分:1)

是肯定的。它们是有区别的。请参阅Form events life cycle。表单加载事件发生在第一次显示表单之前。

尝试使用表格显示的事件。它可能对你有帮助,确保UI线程流畅(我的意思是避免使用消息框类的东西,直到页面完全显示和绘制)。