4.1 KiB
Browser Automation Examples
Common browser automation workflows using the browse CLI. Each example demonstrates a distinct pattern using real commands.
Example 1: Extract Data from a Page
User request: "Get the product details from example.com/product/123"
browse open https://example.com/product/123
browse snapshot # read page structure + element refs
browse get text "body" # extract all visible text content
browse stop
Parse the text output to extract structured data (name, price, description, etc.).
For a specific section, use a CSS selector:
browse get text ".product-details" # text from a specific container
Note: browse get text requires a CSS selector — use "body" for all page text.
Example 2: Fill and Submit a Form
User request: "Fill out the contact form on example.com with my information"
browse open https://example.com/contact
browse snapshot # find form fields and their refs
browse click @0-3 # click the Name input (ref from snapshot)
browse type "John Doe"
browse press Tab # move to next field
browse type "john@example.com"
browse fill "#message" "I would like to inquire about your services"
browse snapshot # verify fields are filled
browse click @0-8 # click Submit button (ref from snapshot)
browse snapshot # confirm submission result
browse stop
Key pattern: Use browse snapshot before interacting to discover element refs, then browse click <ref> and browse type to interact.
Example 3: Multi-Step Navigation
User request: "Get headlines from the first 3 pages of results on example.com/news"
browse open https://example.com/news
browse snapshot # read page 1 content
browse get text ".headline" # extract headlines
browse snapshot # find "Next" button ref
browse click @0-12 # click Next (ref from snapshot)
browse wait load # wait for page 2 to load
browse get text ".headline" # extract page 2 headlines
browse snapshot # find Next again (ref may change)
browse click @0-15 # click Next
browse wait load
browse get text ".headline" # extract page 3 headlines
browse stop
Key pattern: Re-run browse snapshot after each navigation because element refs change when the page updates.
Example 4: Escalate to Remote Mode
User request: "Scrape pricing from competitor.com" (a site with Cloudflare protection)
# Attempt 1: local mode
browse open https://competitor.com/pricing
browse snapshot
# Output shows: "Checking your browser..." (Cloudflare interstitial)
# or: page content is empty / access denied
browse stop
The agent detects bot protection and tells the user:
This site has Cloudflare bot detection. Browserbase remote mode can bypass this with anti-bot stealth and residential proxies. Want me to set it up?
If the user agrees:
# Set Browserbase credentials
export BROWSERBASE_API_KEY="bb_live_..."
export BROWSERBASE_PROJECT_ID="proj_..."
# Retry in remote mode
browse env remote
browse open https://competitor.com/pricing
browse snapshot # full page content now accessible
browse get text ".pricing-table"
browse stop
Tips
- Snapshot first: Always run
browse snapshotbefore interacting — it gives you the accessibility tree with element refs - Use refs to click:
browse click @0-5is more reliable than trying to describe elements - Re-snapshot after actions: Element refs change when the page updates
get textfor data extraction: Usebrowse get text [selector]to pull text content from specific elementsstopwhen done: Alwaysbrowse stopto clean up the browser session- Prefer snapshot over screenshot: Snapshot is fast and structured; screenshot is slow and uses vision tokens. Only screenshot when you need visual context (layout, images, debugging)