下面的代码解决了您的一些问题。
主要问题是您没有正确初始化s
并且您获取所选行的字段的方式存在缺陷。
调用DataSet.Disable/EnableControls
和ListBox1.Items.BeginUpdate/EndUpdate
是为了加快进程。
另外,避免with
像瘟疫这样的构造。如您所见,我使用局部DataSet
变量只需要最少的额外输入,并避免使用with
.
procedure TForm1.GetSelected;
var
i,
J : Integer;
s : String;
DataSet : TDataSet;
begin
if DBGrid1.SelectedRows.Count>0 then begin
DataSet := DBGrid1.DataSource.DataSet;
// with DBGrid1.DataSource.DataSet do
try
ListBox1.Items.BeginUpdate;
DataSet.DisableControls;
for i:=0 to DBGrid1.SelectedRows.Count-1 do
begin
DataSet.GotoBookmark(Pointer(DBGrid1.SelectedRows.Items[i]));
s := '';
for j := 0 to DataSet.FieldCount - 1 do
begin
if (j>0) then s:=s+', ';
s := s + DataSet.Fields[j].AsString;
//s := s + FindField(Fields.Fields[j].FieldName).AsString;
end;
Listbox1.Items.Add(s);
//s:= '';
end;
finally
DataSet.EnableControls;
ListBox1.Items.EndUpdate;
end;
end;
end;
**更新: **
您可以像这样将当前网格行设置为选中状态
DBGrid1.SelectedRows.CurrentRowSelected := True;
更新#2
网格的选定行存储在TBookmarkList
命名的SelectedRow
. 要清除当前选择,您需要做的就是调用它的Clear
方法,如下所示:
procedure TForm1.btnClearSelectedClick(Sender: TObject);
begin
DBGrid1.SelectedRows.Clear;
end;
同样,如果要清除 ListBox,只需调用它的Clear
方法,如下所示:
procedure TForm1.btnClearListBoxClick(Sender: TObject);
begin
ListBox1.Clear;
end;
如果您无法让我的代码正常工作,请尝试以下操作:
在对象检查器中,将 DBGrid Options 属性设置dgMultiSelect
为 True。
在您的表单及其OnClick
处理程序调用中放置一个按钮GetSelected
。
编译并运行。单击网格中的一行,然后单击按钮。什么都没发生。原因是单击按钮会将焦点从 DBGrid 移开,因此就它而言,没有选择任何行。然后尝试第 3 步。
- 再次运行应用程序。这次按住Ctrl键,同时单击网格,然后单击按钮。这次选定的行出现在 ListBox 中。在Ctrl按钮仍然向下的情况下,单击网格中的另一行,然后单击按钮。这一次,两行都添加到 ListBox。