GitXplorerGitXplorer
j

playwright-relative-selector

public
5 stars
1 forks
0 issues

Commits

List of commits on branch master.
Unverified
f872506f6b5c62926723dca81092b2be5f9bfc51

0.4.0

jjfgreffier committed 4 years ago
Unverified
dac3a23f9dfbd33e48e33bb90cb5c4f27c349e05

Remove package-lock to avoid automatic check. Use this package at your own risks !!!

jjfgreffier committed 4 years ago
Unverified
81f66340b88d2e4f3eba2c3565efd063fd96c197

No dependabot

jjfgreffier committed 4 years ago
Unverified
35cbcd76db7f0c57a0eaf4041e13849202b0486f

Update documentation

jjfgreffier committed 4 years ago
Unverified
cec67e25e23a0a94331d77f1ec8c52d42ddf8675

0.3.2

jjfgreffier committed 4 years ago
Verified
4cdc4af1bd33215086df3a05af734bca116238cc

Update dependabot.yml

jjfgreffier committed 4 years ago

README

The README file for this repository.

🎭 Playwright relative selector

npm version Actions Status Code Coverage

Selecting elements based on layout is native to Playwright since 1.8.0

await page.click(':text("Sign In"):right-of(#home)');

Please refer to Playwright's documentation https://playwright.dev/docs/selectors#selecting-elements-based-on-layout


Click to see depreciated documentation

Playwright helper to locate elements relative to others

Usage

npm install --save-dev playwright-relative-selector

Once installed, you can require this package in a Node.js script and use it with Playwright.

const relativeSelector = require('playwright-relative-selector');

const clickMeElement = await relativeSelector(page, 'text="Sign In" toRightOf css=#home');
await clickMeElement.click();

Selectors

Available selectors:

  • above
  • below
  • toLeftOf
  • toRightOf
  • near

An element is considered relative to another if the distance between the two is of 30px or less.

Examples

First example

This code snippet sets a page with three buttons and clicks on the 'Click me' element on the right of 'Middle'

const { firefox } = require('playwright');
const relativeSelector = require('playwright-relative-selector');

(async () => {
  const browser = await firefox.launch({ headless: false });
  const context = await browser.newContext();
  const page = await context.newPage();
  await page.setContent(`
    <div>
      <button>Click me</button><span>Middle</span><button>Click me</button>
    </div>
  `);

  const clickMeElement = await relativeSelector(page, 'text="Click me" toRightOf text="Middle"');
  await clickMeElement.click();

  await browser.close();
})();