从Puppeteer中的单个选择器获取多个属性

时间:2019-12-05 07:33:29

标签: javascript html reactjs puppeteer

我刚刚在 App.js 中创建了一个具有以下内容的新React应用:

import React from 'react';
import logo from './logo.svg';
import './App.css';

function App() {
  return (
    <div className="App">
      <header className="App-header">
        <img src={logo} className="App-logo" alt="logo" />
        <p>
          Edit <code>src/App.js</code> and save to reload.
        </p>
        <a
          className="App-link"
          href="https://reactjs.org"
          target="_blank"
          rel="noopener noreferrer"
        >
          Learn React
        </a>
      </header>
    </div>
  );
}

export default App;

如果您不了解React,只需考虑return语句(基本HTML)中的内容。

我想用Puppeteer进行端到端测试,所以我的** App.test.js••看起来像:

import puppeteer from "puppeteer";

let browser;
let page;

beforeAll(async () => {
  browser = await puppeteer.launch({
    headless: false
  });
  page = await browser.newPage();
  await page.goto("http://localhost:3000/");
});

test("renders learn react link", async () => {
  await page.waitForSelector(".App");

  const header = await page.$eval(".App-header>p", e => e.innerHTML);
  expect(header).toBe(`Edit <code>src/App.js</code> and save to reload.`);

  const link = await page.$eval(".App-header>a", e => e);
  expect(link.innerHTML).toBe(`Learn React`);
  expect(link.href).toBe("https://reactjs.org");
  console.log(link);
});

afterAll(() => {
  browser.close();
});

请注意,link常量及其后的4行。他们不工作。一种可行的方法是,如果我执行以下操作:

const linkInnerHTML = await page.$eval(".App-header>a", e => e.innerHTML);
const linkHref = await page.$eval(".App-header>a", e => e.href);
expect(linkInnerHTML).toBe(`Learn React`);
expect(linkHref).toBe("https://reactjs.org");

但是,我希望能够调用一次选择器.App-header>a,然后在其上调用innerHTMLhref。 我知道这很简单,但似乎无法在Google?上正确搜索

有任何线索吗?

1 个答案:

答案 0 :(得分:1)

您无法从page.$eval返回整个节点元素,因为它们不可序列化,但是您可以返回像这样的简单对象:

const link = await page.$eval(".App-header>a", e => {
    return {
        InnerHTML : e.innerHTML,
        Href : e.href,
    }
});

expect(link.InnerHTML).toBe(`Learn React`);
expect(link.Href).toBe("https://reactjs.org");