从元素丢失焦点而不重置浏览器的垂直滚动条

时间:2015-11-30 11:04:26

标签: javascript c# selenium webdriver action

我创建了一个自定义命令,失去了当前web元素的焦点,如下所示:

public void LoseFocus()
{
    int? scrollPositionY = Driver.Current.GetIntValueUsingScript("return $(document).scrollTop();");
    this.ClickOnElementsCoordinates(Driver.Current.FindElement(By.TagName("body")), 0, scrollPositionY.Value);
}

public void ClickOnElementsCoordinates(IWebElement element, int positionX, int positionY)
{
    var builder = new OpenQA.Selenium.Interactions.Actions(Driver.Current);
    builder.MoveToElement(element, positionX, positionY)
        .Click().Build().Perform();
    builder.Release();
}

问题在于,每次调用LoseFocus()时,它都会将垂直滚动位置设置为0.左垂直滚动条不应更改当前位置。我该如何实现这一目标? 我也试过像这样使用javascript

ExecuteScript(null, "document.elementFromPoin(0,""+scrollPositionY.Value+"").click();");

但同样的事情发生了。

编辑1

在上面的c#代码中我得到了当前的垂直滚动条位置。然后我点击坐标上的'body'元素(0,滚动pos.Y)。我这样做是为了防止滚动条改变其当前的Y坐标,但仍然不起作用。

编辑2

这里还有一个示例html sample html

1 个答案:

答案 0 :(得分:0)

我实现的所有逻辑都是正确的,除非我需要点击offsetY而不是absoluteY坐标,所以不需要传递任何元素(在我的案例文档中)。

// Wrong
builder.MoveToElement(element, posX, posY)

// Correct, clicking on document's offset
builder.MoveByOffset(posX, posY)