详细分析 ▾
运行时依赖
版本
Initial release of playwright-npx: Fast Node.js scripting for browser automation with Playwright. - Provides usage guide for browser tasks: scraping, screenshots, form automation, and custom workflows. - Includes quick setup, minimal script examples, and patterns for screenshots, scraping, form automation, and dynamic content handling. - Documents persistent session techniques, headless/headed debugging, and selector strategies. - Lists working script templates and example files for rapid development. - Offers troubleshooting, debugging, and selector reference links for deeper guidance.
安装命令 点击复制
技能文档
🤝 Developed together by Kuba + Mahone · Feb 2026
Code-first browser automation with Playwright.
当...时 到 使用
| Tool | Use When |
|---|---|
| web_fetch | Simple pages, no JavaScript needed |
| This skill | JavaScript-heavy sites, complex interactions, full control |
| stealth-browser | Bot detection / Cloudflare issues |
| browser tool | Visual exploration, last resort |
| playwright-cli | Interactive CLI without writing code |
Setup
# One-time per project
npm init -y
npm install playwright
npx playwright install chromium
包.json 示例:
{
"name": "my-automation",
"type": "module",
"dependencies": {
"playwright": "^1.40.0"
}
}
Minimal 示例
// tmp/example.mjs
import { chromium } from 'playwright';const browser = await chromium.launch();
const page = await browser.newPage();
await page.goto('https://example.com');
console.log('Title:', await page.title());
await browser.close();
node tmp/example.mjs
Quick Patterns
Screenshot
import { chromium } from 'playwright';
const browser = await chromium.launch();
const page = await browser.newPage();
await page.setViewportSize({ width: 1280, height: 800 });
await page.goto('https://example.com');
await page.screenshot({ path: 'tmp/screenshot.png', fullPage: true });
await browser.close();
Scrape Data
import { chromium } from 'playwright';
const browser = await chromium.launch();
const page = await browser.newPage();
await page.goto('https://news.ycombinator.com');
const stories = await page.$$eval('.titleline > a', links =>
links.slice(0, 5).map(a => ({ title: a.innerText, url: a.href }))
);
console.log(JSON.stringify(stories, null, 2));
await browser.close();
表单 Interaction
await page.goto('https://example.com/login');
await page.fill('input[name="email"]', 'user@example.com');
await page.fill('input[name="password"]', 'password');
await page.click('button[type="submit"]');
Wait 对于 Dynamic Content
// Wait for network idle (SPA)
await page.goto(url, { waitUntil: 'networkidle' });// Wait for specific element
await page.waitForSelector('.results', { timeout: 10000 });
// Wait for condition
await page.waitForFunction(() =>
document.querySelectorAll('.item').length > 0
);
Persistent 会话
import fs from 'fs';
const SESSION_FILE = 'tmp/session.json';let context;
if (fs.existsSync(SESSION_FILE)) {
context = await browser.newContext({ storageState: SESSION_FILE });
} else {
context = await browser.newContext();
}
const page = await context.newPage();
// ... login ...
await context.storageState({ path: SESSION_FILE });
Headless vs Headed
// Headless (default, fastest)
await chromium.launch({ headless: true });// Headed (see the browser)
await chromium.launch({ headless: false });
// Slow motion (debugging)
await chromium.launch({ headless: false, slowMo: 100 });
Selectors Quick Reference
// CSS
await page.click('button.submit');
await page.fill('input#email', 'text');// Text content
await page.click('text=Submit');
await page.click('text=/log\s*in/i'); // regex
// XPath
await page.click('xpath=//button[@type="submit"]');
// ARIA role
await page.click('role=button[name="Submit"]');
// Test ID (most stable)
await page.click('[data-testid="submit-btn"]');
// Chain selectors
await page.click('nav >> text=Settings');
See references/selectors.md 对于 complete selector guide.
错误 Handling
try {
await page.goto('https://example.com', { timeout: 30000 });
const hasResults = await page.locator('.results').isVisible().catch(() => false);
if (!hasResults) {
console.log('No results');
process.exit(0);
}
} catch (error) {
console.error('Error:', error.message);
await page.screenshot({ path: 'tmp/error.png' });
process.exit(1);
} finally {
await browser.close();
}
Examples & Templates
Working Examples
- examples/screenshot.mjs - 满-page screenshots
- examples/scrape.mjs - Data extraction
- examples/表单-interaction.mjs - 表单 automation
- examples/登录-会话.mjs - Persistent sessions
Reusable Templates
- scripts/minimal-模板.mjs - Clean starting point
- scripts/screenshot-模板.mjs - Configurable screenshot
- scripts/scrape-模板.mjs - Data scraping scaffold
复制 templates:
cp scripts/minimal-template.mjs tmp/my-task.mjs
# Edit tmp/my-task.mjs, then run:
node tmp/my-task.mjs
Tooling Commands
# Record interactions to generate code
npx playwright codegen https://example.com# Debug selectors
npx playwright codegen --target javascript https://example.com
# Show trace
npx playwright show-trace tmp/trace.zip
Deep References
- references/selectors.md - Complete selector guide (CSS, text, XPath, ARIA, test-id)
- references/debugging.md - Debugging techniques (headless, slowMo, screenshots)
- references/troubleshooting.md - Common errors 和 solutions
Tips
- Always put scripts 在...中
tmp/— 's gitignored - 使用
.mjs扩展 对于 ES modules (否类型: 模块needed) - 添加
console.log()liberally 对于 debugging - 使用
page.screenshot()当...时 things go wrong - 对于 complex sites, 添加
等待 page.waitForLoadState('networkidle') - See references/debugging.md 对于 detailed debugging guide
- See references/troubleshooting.md 对于 common issues
免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制