加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

delphi – 返回先前位置时如何避免TDbgrid滚动

发布时间:2020-12-15 09:13:39 所属栏目:大数据 来源:网络整理
导读:在下面的代码中,我们对某些选定的行执行一些操作(而不是删除). 但是,有时,完成后,顶部选定的行已滚动,以便在网格下方显示1/2.有没有办法避免这种滚动? (如果我的代码遍历下面的选定行是不正确的,由于一些无关的原因,我欢迎更正.) Function TForm.DoSomethin
在下面的代码中,我们对某些选定的行执行一些操作(而不是删除).

但是,有时,完成后,顶部选定的行已滚动,以便在网格下方显示1/2.有没有办法避免这种滚动? (如果我的代码遍历下面的选定行是不正确的,由于一些无关的原因,我欢迎更正.)

Function TForm.DoSomethingToSelectedRows;
  var
    KeyAtStart: Integer;
  begin
    Result := TRUE;
    KeyAtStart := DataSet.FieldByName('Key').AsInteger;
    DataSet.DisableControls;
    DataSet.First;
    try
      while Result AND (NOT DataSet.EOF) do  DataSet
        begin
          if DBGrid1.SelectedRows.CurrentRowSelected then
            Result := ... do something ...
          fMPODataTls.GetDS.Next;
        end;
    finally
      DataSet.Locate('Key',KeyAtStart,[]);    // re-position where we started
      DataSet.EnableControls;
    end;
  end;

解决方法

在循环遍历数据集之前,您可以记下网格显示的顶行以及显示的总记录数.有了这些信息,在重新定位记录后,您可以将记录定位到确切的行,方法是移动到顶部或底部,然后再移回.

你可以通过MoveBys进行移动.不幸的是,TDBGrid的Row和RowCount属性受到保护,因为你必须使用众所周知的“受保护的黑客”.

在this答案中有代码示例,以及检查书签,这样您就不会以错误的记录结束.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读