当对象不可见时触发 Link 次点击
Trigger a Link Click When an Object is Not Visible
我正在使用 UFT 12.51 在 IE11 上自动化基于 Web 的应用程序。这是我的场景:
我必须浏览几页才能完成我试图自动化的过程(准确地说是 9 页)。在第 4 页上,我单击 link 打开一个框架(作为弹出窗口)。我输入所需的信息,然后单击按钮提交关闭框架和 returns 我到浏览器上的第 4 页的信息。这是我的问题开始的地方:此时 UFT 停止识别页面上的任何元素。它发现有一个页面,但没有识别出它有任何子 'visible' 对象。如果我再次手动单击 link 以再次显示框架并关闭框架,UFT 将再次开始识别页面上的对象。当 link 对 UFT 不可见时,有没有一种方法可以触发 link 单击(我有 URL)再次打开框架?如果我能做到这一点,我将能够关闭框架,页面上的对象将再次可见。希望 :)
我已经尝试过 'devicereplay'、browser.navigate、sendkeys 之类的东西,但其中 none 可以正常工作。不幸的是,由于我的应用程序的性质,我无法提供任何屏幕打印。任何帮助将不胜感激,因为我已经尝试解决这个问题 2 天了,但没有运气。
代码
Dim oDR : Set oDR = CreateObject("Mercury.DeviceReplay")
' Lets get the X and Y chordinates for 'Next Step' button
Dim iX, iY
iX = Browser("MyBrowser").Page("MyPage").Link("NextStep").GetROProperty("x") + 5
iY = Browser("MyBrowser").Page("MyPage").Link("NextStep").GetROProperty("y") + 5
If MyFunction(dCurrVals, sErrorMsg) Then
LOG_ReportEvent "PASS", "Set Investment/Allocate", "Successfully initialised page"
Else
LOG_ReportEvent "FAIL", "Set Investment/Allocate", sError
End If
'Browser("MyBrowser").Page("MyPage").Object.body.doscroll "scrollbarPageUP"
wait(1)
oDR.MouseMove iX, iY
oDR.MouseClick iX, iY, 0
Set oDR = Nothing
Browser("MyBrowser").RefreshWebSupport
Wait(1)
Browser("MyBrowser").Page("MyPage").Link("Search")
'Browser("MyBrowser").Navigate "MyURL"
'Browser("MyBrowser").Page("MyPage").Sync
'Browser("MyBrowser").Page("MyPage").Link
'Wait(1)
'Browser("MyBrowser").Page("MyPage").Link("Search")
'Browser("MyBrowser").Page("MyPage").WebElement("Search").FireEvent "onclick"
注意
出于安全原因,我更改了对象的名称,但上面的代码只是我尝试过的示例。 dCurrVals
是一个字典对象,它在函数调用之前被预填充
这听起来像是 UFT 中的错误,您应该联系 HPE 的支持。
此类情况的解决方法在未记录的 Browser("...").RefreshWebSupport
method 中可用,它告诉 UFT re-connect 到浏览器的 DOM。这可能会有所帮助,但由于它没有记录,因此无法保证:(
经过大量研究,我找到了解决这个问题的办法。我想不出另一种方法来解决这个问题。我想我会把它放在这里以防其他人遇到同样的问题
接近
由于 UFT 无法识别页面上的任何内容,我决定使用 InsightObject
。使用 InsightObject
的优点是只要对象可见,UFT 就会在页面上找到它。具有讽刺意味的是,这也是一个缺点:对象必须在屏幕上可见。所以我决定编写下面的 UDF。 UDF 移动到页面顶部,然后搜索 InsightObject
。如果未找到该对象,它会将页面向下移动并再次搜索该对象。它重复此过程,直到找到对象或达到计数器限制。如果找到 InsightObject
,它会单击该对象,然后检查页面上的指定对象。
UDF
Public Function EnablePage(ByVal oInsightObject, ByVal oCheckObject, ByVal iPgMoveCount ByRef sError)
LOG_Write vbNewLine & "EnablePage"
Dim oWS: Set oWS = CreateObject("WScript.shell")
Dim iC
Dim bFoundIO
' Set default values
EnablePage = True
bFoundIO = False
' Move to the top of the page
For iC = 1 To CInt(iPgMoveCount)
oWS.SendKeys "{PGUP}"
Wait 0, 500
Next
' Navigate to the bottom of the page to find the object
For iC = 1 To CInt(iPgMoveCount)
' Check if Insight object exists
If oInsightObject.Exist(1) Then
bFoundIO = True
oInsightObject.Click
Wait 0, 500
Exit For
Else
oWS.SendKeys "{PGDN}"
Wait 0, 500
End If
Next
' Check if Insight object was found
If bFoundIO Then
' Check if object to check is visible
If Not oCheckObject.Exist(2) Then
EnablePage = False
sError = "Clicked on Insight Object but unable to find the object to check"
End If
Else
EnablePage = False
sError = "Unable to find the Insight Object"
End If
' Clear objects
Set oWS = Nothing
End Function
我正在使用 UFT 12.51 在 IE11 上自动化基于 Web 的应用程序。这是我的场景:
我必须浏览几页才能完成我试图自动化的过程(准确地说是 9 页)。在第 4 页上,我单击 link 打开一个框架(作为弹出窗口)。我输入所需的信息,然后单击按钮提交关闭框架和 returns 我到浏览器上的第 4 页的信息。这是我的问题开始的地方:此时 UFT 停止识别页面上的任何元素。它发现有一个页面,但没有识别出它有任何子 'visible' 对象。如果我再次手动单击 link 以再次显示框架并关闭框架,UFT 将再次开始识别页面上的对象。当 link 对 UFT 不可见时,有没有一种方法可以触发 link 单击(我有 URL)再次打开框架?如果我能做到这一点,我将能够关闭框架,页面上的对象将再次可见。希望 :)
我已经尝试过 'devicereplay'、browser.navigate、sendkeys 之类的东西,但其中 none 可以正常工作。不幸的是,由于我的应用程序的性质,我无法提供任何屏幕打印。任何帮助将不胜感激,因为我已经尝试解决这个问题 2 天了,但没有运气。
代码
Dim oDR : Set oDR = CreateObject("Mercury.DeviceReplay")
' Lets get the X and Y chordinates for 'Next Step' button
Dim iX, iY
iX = Browser("MyBrowser").Page("MyPage").Link("NextStep").GetROProperty("x") + 5
iY = Browser("MyBrowser").Page("MyPage").Link("NextStep").GetROProperty("y") + 5
If MyFunction(dCurrVals, sErrorMsg) Then
LOG_ReportEvent "PASS", "Set Investment/Allocate", "Successfully initialised page"
Else
LOG_ReportEvent "FAIL", "Set Investment/Allocate", sError
End If
'Browser("MyBrowser").Page("MyPage").Object.body.doscroll "scrollbarPageUP"
wait(1)
oDR.MouseMove iX, iY
oDR.MouseClick iX, iY, 0
Set oDR = Nothing
Browser("MyBrowser").RefreshWebSupport
Wait(1)
Browser("MyBrowser").Page("MyPage").Link("Search")
'Browser("MyBrowser").Navigate "MyURL"
'Browser("MyBrowser").Page("MyPage").Sync
'Browser("MyBrowser").Page("MyPage").Link
'Wait(1)
'Browser("MyBrowser").Page("MyPage").Link("Search")
'Browser("MyBrowser").Page("MyPage").WebElement("Search").FireEvent "onclick"
注意
出于安全原因,我更改了对象的名称,但上面的代码只是我尝试过的示例。 dCurrVals
是一个字典对象,它在函数调用之前被预填充
这听起来像是 UFT 中的错误,您应该联系 HPE 的支持。
此类情况的解决方法在未记录的 Browser("...").RefreshWebSupport
method 中可用,它告诉 UFT re-connect 到浏览器的 DOM。这可能会有所帮助,但由于它没有记录,因此无法保证:(
经过大量研究,我找到了解决这个问题的办法。我想不出另一种方法来解决这个问题。我想我会把它放在这里以防其他人遇到同样的问题
接近
由于 UFT 无法识别页面上的任何内容,我决定使用 InsightObject
。使用 InsightObject
的优点是只要对象可见,UFT 就会在页面上找到它。具有讽刺意味的是,这也是一个缺点:对象必须在屏幕上可见。所以我决定编写下面的 UDF。 UDF 移动到页面顶部,然后搜索 InsightObject
。如果未找到该对象,它会将页面向下移动并再次搜索该对象。它重复此过程,直到找到对象或达到计数器限制。如果找到 InsightObject
,它会单击该对象,然后检查页面上的指定对象。
UDF
Public Function EnablePage(ByVal oInsightObject, ByVal oCheckObject, ByVal iPgMoveCount ByRef sError)
LOG_Write vbNewLine & "EnablePage"
Dim oWS: Set oWS = CreateObject("WScript.shell")
Dim iC
Dim bFoundIO
' Set default values
EnablePage = True
bFoundIO = False
' Move to the top of the page
For iC = 1 To CInt(iPgMoveCount)
oWS.SendKeys "{PGUP}"
Wait 0, 500
Next
' Navigate to the bottom of the page to find the object
For iC = 1 To CInt(iPgMoveCount)
' Check if Insight object exists
If oInsightObject.Exist(1) Then
bFoundIO = True
oInsightObject.Click
Wait 0, 500
Exit For
Else
oWS.SendKeys "{PGDN}"
Wait 0, 500
End If
Next
' Check if Insight object was found
If bFoundIO Then
' Check if object to check is visible
If Not oCheckObject.Exist(2) Then
EnablePage = False
sError = "Clicked on Insight Object but unable to find the object to check"
End If
Else
EnablePage = False
sError = "Unable to find the Insight Object"
End If
' Clear objects
Set oWS = Nothing
End Function