webcli
// Browse the web, read page content, click buttons, fill forms, take screenshots, and get accessibility snapshots using the webcli headless browser. Use when the user asks to visit a website, gather information from a web page, or interact with a web app.
$ git log --oneline --stat
stars:1,933
forks:367
updated:March 4, 2026
SKILL.mdreadonly
SKILL.md Frontmatter
namewebcli
descriptionBrowse the web, read page content, click buttons, fill forms, take screenshots, and get accessibility snapshots using the webcli headless browser. Use when the user asks to visit a website, gather information from a web page, or interact with a web app.
allowed-toolsBash(webcli *)
webcli — Headless Browser CLI
You have access to a headless browser via the webcli command. Use it to navigate websites, read content, interact with elements, take screenshots, and get accessibility snapshots.
Prerequisites
npm install -g @erdinccurebal/webcli
npx playwright install chromium
Homepage: https://webcli.erdinc.curebal.dev/ Repository: https://github.com/erdinccurebal/webcli
Commands Reference
Navigation
webcli go <url> # Navigate to URL (auto-starts daemon)
webcli go <url> -w networkidle # Wait for network to settle
webcli go <url> -t mytab # Open in named tab
webcli back # Go back in history
webcli forward # Go forward
webcli reload # Reload current page
Reading Page Content
webcli source # Get full visible text of the page
webcli links # List all links (text + href)
webcli forms # List all forms with their inputs
webcli html <selector> # Get innerHTML of element
webcli attr <selector> <attribute> # Get element attribute value
webcli eval "<js>" # Execute JavaScript and return result
webcli title # Get the page title
webcli url # Get the current URL
webcli value <selector> # Get input/textarea value
webcli count <selector> # Count matching elements
webcli box <selector> # Get bounding box (x, y, w, h)
webcli styles <selector> [props..] # Get computed CSS styles
webcli visible <selector> # Check if element is visible
webcli enabled <selector> # Check if element is enabled
webcli checked <selector> # Check if checkbox is checked
Accessibility Snapshot (Recommended for AI agents)
webcli snapshot # Get accessibility tree with refs (@e1, @e2...)
webcli snapshot --all # Include non-interactive elements
webcli snapshot --max-depth 5 # Limit tree depth
The snapshot assigns deterministic refs to interactive elements. Use these refs in other commands:
webcli snapshot # Get tree: [button @e1] "Submit", [textbox @e2] "Email"
webcli fill @e2 "user@example.com" # Fill using ref
webcli click @e1 # Click using ref
Interaction
webcli click "<visible text>" # Click element by visible text
webcli click @e1 # Click element by snapshot ref
webcli clicksel "<css selector>" # Click element by CSS selector
webcli dblclick "<text>" # Double-click element by visible text
webcli hover "<selector>" # Hover over an element
webcli fill "<selector>" "<value>" # Fill an input field (preferred for forms)
webcli type "<text>" # Type with keyboard (for focused element)
webcli select "<selector>" "<val>" # Select dropdown option
webcli press Enter # Press keyboard key (Enter, Tab, Escape...)
webcli focus "<selector>" # Focus an element
webcli check "<selector>" # Check a checkbox
webcli uncheck "<selector>" # Uncheck a checkbox
webcli drag "<from>" "<to>" # Drag and drop between selectors
webcli upload "<selector>" <file> # Upload a file to input[type=file]
webcli scroll down 500 # Scroll page (up/down/left/right, px)
Waiting
webcli wait "<selector>" # Wait for CSS selector to be visible
webcli waitfor "<text>" # Wait for text to appear on page
webcli sleep 2000 # Sleep for N milliseconds
Screenshots & PDF
webcli screenshot # Take full-page screenshot (returns path)
webcli screenshot -o page.png # Save to specific file
webcli screenshot --no-full # Viewport-only screenshot
webcli screenshot --annotate # Screenshot with numbered interactive elements
webcli pdf # Save page as PDF
webcli pdf -o page.pdf # Save PDF to specific file
Console & Errors
webcli console on # Start capturing console messages
webcli console off # Stop capturing
webcli console # Show captured console messages
webcli errors # Show page errors
Dialog Handling
webcli dialog accept # Accept alert/confirm dialog
webcli dialog accept "input text" # Accept prompt dialog with text
webcli dialog dismiss # Dismiss dialog
Frame (iframe) Switching
webcli frame "<selector>" # Switch to an iframe
webcli frame main # Switch back to main frame
Storage (localStorage)
webcli storage get # Get all localStorage
webcli storage get mykey # Get specific key
webcli storage set mykey myvalue # Set a value
webcli storage clear # Clear all localStorage
State Management
webcli state save session.json # Save cookies + localStorage + sessionStorage
webcli state load session.json # Restore full browser state
Browser Settings
webcli viewport 1920 1080 # Change viewport size
webcli useragent "<string>" # Change user agent
webcli device "iPhone 14" # Emulate device (viewport + UA)
webcli network on # Start logging network requests
webcli network off # Stop logging
webcli network # Show network logs
Cookie Management
webcli cookie export # Export cookies as JSON
webcli cookie import <file> # Import cookies from JSON file
Tab & Daemon Management
webcli tabs # List open tabs
webcli quit # Close current tab
webcli quit -t mytab # Close specific tab
webcli status # Show daemon info (PID, uptime, tabs)
webcli stop # Stop daemon and close browser
Global Options
All commands support:
-t, --tab <name>— target a specific tab (default: "default")--json— output as structured JSON--timeout <ms>— command timeout (default: 30000)
Best Practices
Recommended workflow for AI agents
webcli go <url>to navigatewebcli snapshotto get accessibility tree with refs- Use refs for interaction:
webcli click @e1,webcli fill @e2 "value" webcli snapshotagain to see updated statewebcli screenshotif user wants visual confirmation
Alternative workflow (text-based)
webcli go <url>to navigatewebcli sourceto read the page content- Use
webcli click,webcli fill,webcli pressto interact webcli sourceagain to see the result
Form filling
- Always use
webcli fillfor input fields — it properly sets React/Vue controlled inputs - Use
webcli clickorwebcli clickselfor buttons - Use
webcli press Enterto submit forms - After submitting, use
webcli sleep 1000thenwebcli sourceto check the result
Multi-tab browsing
webcli go https://site-a.com -t research
webcli go https://site-b.com -t reference
webcli source -t research # Read from specific tab
webcli source -t reference
Error recovery
- If a command times out, try
webcli sleep 2000then retry - If an element is not found, use
webcli sourceto check what's on the page - If the daemon seems stuck, use
webcli stopthen retry the command - Use
webcli wait "<selector>"before interacting with dynamically loaded content
Important Notes
- Always read the page with
webcli sourceorwebcli snapshotbefore trying to interact - Prefer
webcli snapshot+ refs for the most reliable element targeting - Prefer
webcli filloverwebcli typefor form inputs - Prefer
webcli click(by text) overwebcli clicksel(by selector) when possible - Use
webcli sleepbetween rapid interactions to let pages update - The daemon persists between commands — no need to re-navigate unless the page changes