如何使用Protractor/Selenium将鼠标移动到任意点?

22

在Protractor测试中,是否可以将鼠标移动到屏幕上的任意坐标/相对于元素的位置?我看到有人建议Java用户使用Robot,但当然我不能在JavaScript中使用它。


4
如果您给这个帖子投了反对票,能否请您解释一下原因? - Andy
3个回答

39

我自己找到了答案...只是花了很多时间深入研究了 Protractor 和 Selenium 的文档。这是一些示例代码:

  it('should pan plots when you click and drag', function() {
    var plot0 = element(by.css('.plot > canvas'));
    browser.actions()
      .mouseMove(plot0, {x: 100, y: 100}) // 100px from left, 100 px from top of plot0
      .mouseDown()
      .mouseMove({x: 400, y: 0}) // 400px to the right of current location
      .perform();
  });

1
这对我现在非常有帮助。+1 - bob.mazzo

4
我还找到了一种模拟滑动操作的解决方案。
var card = element(by.css('#card'));

browser.actions()
  .mouseMove(card, {x: 100, y: 100})
  .mouseDown()
  .mouseMove({x: 0, y: -400})
  .perform();

browser.sleep(500);

browser.actions()
  .mouseUp()
  .perform();

0
var graphDimensions = {// see [1]
  Width: 0,
  Height: 0
};
company_page.company_Chart_Graph().getAttribute('width')
  .then(function(width) {
    graphDimensions.Width = parseInt(width);
  });

company_page.company_Chart_Graph().getAttribute('height').then(function(height) {
  graphDimensions.Height = parseInt(height);

  console.log('W' + graphDimensions.Width);
  console.log('H' + graphDimensions.Height);

  var plot0 = company_page.company_Chart_Graph();
  browser.actions()
    .mouseMove(plot0, {
      x: 0,
      y: 0
    })
    .mouseDown()
    .mouseMove(plot0, {
      x: graphDimensions.Width,
      y: graphDimensions.Height
    })
    .mouseUp()
    .perform();

  browser.driver.sleep(23000);
  company_page.company_ReportDownload().click();
  browser.driver.sleep(23000);
});

[1]: http://testingalert.com/

[1]: http://testingalert.com/

的翻译是:


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接