【问题标题】:refresh vb6 form in background without losing user entered data在后台刷新 vb6 表单而不会丢失用户输入的数据
【发布时间】:2012-12-26 04:28:56
【问题描述】:

我正在使用一些旧的 VB6 代码,并且有一个我正在尝试纠正的场景。我有一个表格,允许您输入个人 ID(在顶部的文本框中使用租户),然后单击“显示”,它会在同一表格的文本框中列出约会。还有一个按钮可以加载一个新表单,允许用户编辑显示的数据并保存更改。

例如将人的年龄从 65 岁更改为 64 岁。我进行此更改并保存它。保存成功,我卸载表单返回Form1。但是,我必须再次单击“显示”以刷新文本框中显示的数据,以确保更改可见。我不知道如何刷新此表单,因此用户不必单击“显示”即可使用新值重新填充文本框。有人可以帮忙吗?我不能只创建 Form1 的新实例,因为如果我这样做了,则人员 ID 字段将是空白的。

谢谢!

短版:如何刷新表单以获取最新数据,同时仍获取相关人员 ID。

【问题讨论】:

    标签: forms vb6 refresh


    【解决方案1】:

    这里没有足够的信息来回答您的问题。您在这种情况下使用的一般模式如下:

    1. SearchForm 启动 ViewForm。
    2. ViewForm 启动 EditForm。当 ViewForm 构造它的 EditForm 实例时,它会将 Me 传递给 EditForm(可能通过设置 EditForm.Parent)。
    3. 当 EditForm 的 Save 按钮单击事件触发时,它会调用 Parent.ReloadData(其中 Parent 是启动 EditForm 的 ViewForm)。

    【讨论】:

      【解决方案2】:

      这是应该有效的方法。在编辑器中有一个公共属性,它返回表单是否被取消。 (。取消)。您将拥有一个对象,该对象带有您尝试更改其年龄的人的属性。然后就很简单了。主窗体中的代码:

      dim oPerson as clsPerson
      dim oFrm as frmAgeEditor
      
      set oPerson = GetCurrentPerson()
      set oFrm = new frmAgeEditor
      
      
      with oFrm
          set .Person = oPerson
          .Show vbModal
      
          if not .Cancelled then
              ' Update Main form with the contents of oPerson
      
          end if
      
      end with 
      

      【讨论】:

        【解决方案3】:

        您可以在更新后立即调用“显示”功能。

        【讨论】:

          【解决方案4】:
          Call Me.frmParent.Refresh
          

          我用它来刷新屏幕而不会丢失数据。 我不得不挖掘很多旧代码才能弄清楚。这部分是很久以前写的,效果很好。

          Public Sub Refresh()
          Call cmdDetails_Click
          If tvwScreeningSchedule.Nodes.Count > 0 Then
              tvwScreeningSchedule.SelectedItem = tvwScreeningSchedule.Nodes(1)
              Call tvwScreeningSchedule_Click
          End If
          
          End Sub
          

          这是一个非常具体的功能,“cmdDetails_Click”包含很多自定义验证,但它与 AngryHackers 的答案并不太相似。

          【讨论】:

            猜你喜欢
            • 1970-01-01
            • 2015-04-20
            • 1970-01-01
            • 2019-02-24
            • 2021-04-13
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            相关资源
            最近更新 更多