我试图在刷新数据后维护 DataGridView 控件的选定行。这是我的代码
public partial class frmPlant : Form
{
string gSelectedPlant;
private void frmPlant_Load(object sender, EventArgs e)
{
dataGridView1.AutoGenerateColumns = true;
dataGridView1.DataSource = bindingSource1;
FillData();
dataGridView1.DataMember = "Table";
}
private void FillData()
{
ds = _DbConnection.returnDataSet(_SQlQueries.SQL_PlantSelect);
bindingSource1.DataSource = ds.Tables[0];
}
public DataSet returnDataSet(string txtQuery)
{
conn.Open();
sqlCommand = conn.CreateCommand();
DB = new SQLiteDataAdapter(txtQuery, conn);
DS.Reset();
DB.Fill(DS);
conn.Close();
return (DS);
}
private void dataGridView1_Selectionchanged(object sender, EventArgs e)
{
if (dataGridView1.SelectedRows.Count > 0)
{
gSelectedPlant = dataGridView1.SelectedRows[0].Cells["PlantId"].Value.ToString();
}
}
private void dataGridView1_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e)
{
int selectedIndex;
if (!string.IsNullOrEmpty(gSelectedPlant) && e.ListChangedType == ListChangedType.Reset)
{
if (ds.Tables.Count > 0)
{
selectedIndex = bindingSource1.Find("PlantId", gSelectedPlant);
if (selectedIndex <= 0)
selectedIndex = 0;
dataGridView1.Rows[selectedIndex].Selected = true;
}
else
{
gSelectedPlant = string.Empty;
}
}
}
}
它仍然无法维护所选行的行索引。它滚动到第 1 行。这是我使用的博客 http://www.makhaly.net/Blog/9
假设,我在 Form1(所有代码所在的位置)上选择一行,然后进入下一个表单,它向我显示了特定 Plant 的详细信息。如果我再次回到第一个表单,按下后退按钮,该行将重置为 1。gSelectedPlant 取值 1 和 selectedindex = 0。这是有道理的,但我还不能弄清楚如何保持该值gSelectedPlant 的。是的,它最初需要一个空值,但在数据绑定完成时它变为 1。