为了同时理解WebDriverJS和Promise付出了一些努力...而大多数示例代码都适用于Python / Java,而不是Javascript。我要做的就是获取页面的完整html。因此,如果您查看WebDriverJS的相同代码:

var webdriver = require('selenium-webdriver');
...
driver.get('http://www.google.com');
driver.findElement(webdriver.By.name('q')).sendKeys('webdriver');
driver.findElement(webdriver.By.name('btnG')).click();
driver.wait(function() {
 return driver.getTitle().then(function(title) {
   return title === 'webdriver - Google Search';
 });
}, 1000);


我试图简单地返回整个html文档,而不仅仅是标题。在Python中,它将是driver.page_source。我从例子中学到了很多,所以我有点困惑。

最佳答案

如果文档不清楚,我通常更喜欢探索源代码。

这是包含相关webdriver.js source的主要getPageSource() function

/**
 * Schedules a command to retrieve the current page's source. The page source
 * returned is a representation of the underlying DOM: do not expect it to be
 * formatted or escaped in the same way as the response sent from the web
 * server.
 * @return {!webdriver.promise.Promise.<string>} A promise that will be
 *     resolved with the current page source.
 */
webdriver.WebDriver.prototype.getPageSource = function() {
  return this.schedule(
      new webdriver.Command(webdriver.CommandName.GET_PAGE_SOURCE),
      'WebDriver.getAllWindowHandles()');
};

07-24 09:38