mcp-browser-lens
Provides AI agents with deep visibility into a running web page's UI by capturing DOM, styles, and screenshots through a lightweight bookmarklet. It facilitates design-to-code comparisons, accessibility audits, and automated CSS debugging directly within an IDE.
README
<div align="center"> <img src="assets/logo.svg" alt="Browser Lens" width="120" height="120"> <h1>browser-lens-mcp</h1> <p><strong>Your browser's UI, deeply understood by your IDE's AI agent.</strong></p> <p> <a href="https://www.npmjs.com/package/browser-lens-mcp"><img src="https://img.shields.io/npm/v/browser-lens-mcp?style=flat-square&color=8b5cf6" alt="npm"></a> <a href="https://www.npmjs.com/package/browser-lens-mcp"><img src="https://img.shields.io/npm/dm/browser-lens-mcp?style=flat-square&color=8b5cf6" alt="downloads"></a> <a href="https://modelcontextprotocol.io"><img src="https://img.shields.io/badge/MCP-Compatible-blue?style=flat-square" alt="MCP"></a> <a href="https://nodejs.org"><img src="https://img.shields.io/badge/Node.js-20%2B-green?style=flat-square" alt="Node"></a> <a href="LICENSE"><img src="https://img.shields.io/badge/License-MIT-yellow?style=flat-square" alt="License"></a> </p> </div>
How It Works
Browser Lens connects your IDE's AI agent to any running web page. Ask about any UI element and get its exact styles, layout, screenshot, and fix suggestions — with zero code changes.
<div align="center"> <img src="assets/architecture-flow.svg" alt="Architecture Flow" width="100%"> </div>
The flow:
- Bookmarklet runs in your browser, captures DOM, CSS, layout, screenshots
- WebSocket streams data in real-time + receives commands from server
- MCP server stores and indexes everything, exposes 30 tools, 12 resources, 5 prompts
- IDE AI agent queries tools via stdio — inspect any element, take screenshots on demand, compare with Figma
Key Capabilities
| Capability | How It Works |
|---|---|
| Deep Element Inspection | live_query_element sends a command to the browser to capture ANY element by CSS selector — even deeply nested ones not in the auto-capture |
| On-Demand Screenshots | trigger_screenshot tells the browser to take a fresh screenshot NOW and returns the image directly to your IDE |
| Figma Comparison | compare_with_figma compares live CSS values against design specs, scores 0-100, generates copy-paste CSS fixes |
| Full Page Analysis | get_full_page_analysis returns structure, design tokens, typography, colors, spacing, accessibility in one call |
| Feature Area Inspection | inspect_feature_area inspects a specific UI section (header, sidebar, form) with all child details |
What Gets Captured
<div align="center"> <img src="assets/bookmarklet-capture.svg" alt="Bookmarklet Captures" width="100%"> </div>
| Category | Data | Details |
|---|---|---|
| DOM | Full tree + element details | Tags, classes, attributes, text, semantic structure |
| CSS | Computed styles | Every CSS property for any element via selector |
| CSS | Variables | All --* custom properties from :root and stylesheets |
| CSS | Typography | Font families, sizes, weights, line-heights with usage counts |
| CSS | Colors | Text, background, border colors with hex values and counts |
| Layout | Box model | Width, height, padding, margin, border dimensions |
| Layout | Flex & Grid | Direction, wrap, gap, template columns/rows |
| Layout | Spacing | Margin/padding analysis, spacing scale, inconsistencies |
| Visual | Screenshots | On-demand viewport capture as PNG, returned as image |
| Visual | Figma comparison | Compare element against design specs with score + diff |
| A11y | Accessibility | ARIA labels, roles, alt text, headings, landmarks |
| Responsive | Viewport | Dimensions, DPR, active media queries, breakpoints |
| Mutations | DOM changes | Attribute changes, added/removed nodes in real-time |
Quick Start
Step 1 — Configure your IDE
<details open> <summary><strong>Cursor</strong></summary>
File: .cursor/mcp.json
{
"mcpServers": {
"browser-lens": {
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"]
}
}
}
</details>
<details> <summary><strong>VS Code (Copilot)</strong></summary>
File: .vscode/mcp.json
{
"servers": {
"browser-lens": {
"type": "stdio",
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"]
}
}
}
</details>
<details> <summary><strong>Antigravity (Google)</strong></summary>
File: ~/.gemini/antigravity/mcp_config.json
Open via:
...menu (top right) → MCP Servers → Manage MCP Servers → View raw config
{
"mcpServers": {
"browser-lens": {
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"],
"env": {
"MCP_BROWSER_LENS_PORT": "3300",
"MCP_BROWSER_LENS_WS_PORT": "3301",
"MCP_BROWSER_LENS_CDP_PORT": "9222"
}
}
}
}
After saving, click Refresh in Manage MCP Servers.
Usage in Antigravity chat:
@browser-lens Chụp screenshot cho tôi xem
@browser-lens/css-colors Show me the color palette
/compare_with_figma
</details>
<details> <summary><strong>Claude Code</strong></summary>
claude mcp add browser-lens npx -y browser-lens-mcp@latest
</details>
<details> <summary><strong>Windsurf</strong></summary>
File: ~/.codeium/windsurf/mcp_config.json
{
"mcpServers": {
"browser-lens": {
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"]
}
}
}
</details>
<details> <summary><strong>OpenCode</strong></summary>
File: ~/.config/opencode/config.json
{
"mcpServers": {
"browser-lens": {
"type": "local",
"command": ["npx", "-y", "browser-lens-mcp@latest"]
}
}
}
</details>
<details> <summary><strong>Zed</strong></summary>
File: ~/.config/zed/settings.json
{
"context_servers": {
"browser-lens": {
"command": { "path": "npx", "args": ["-y", "browser-lens-mcp@latest"] }
}
}
}
</details>
Custom ports (avoid conflicts):
{
"mcpServers": {
"browser-lens": {
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"],
"env": {
"MCP_BROWSER_LENS_PORT": "3300",
"MCP_BROWSER_LENS_WS_PORT": "3301"
}
}
}
}
Step 2 — Connect your browser
Option A: Chrome Extension (recommended — persists across page reloads)
# Find the extension folder
ls node_modules/browser-lens-mcp/extension/
- Open
chrome://extensionsin Chrome/Edge - Enable Developer Mode (top right)
- Click Load unpacked
- Select
node_modules/browser-lens-mcp/extension/ - Done — auto-connects on every page load, survives reload!
Configure ports via the extension popup icon.
Option B: Bookmarklet (zero install, one-time per page)
- Open http://localhost:3202 (or your custom port)
- Drag the bookmarklet to your bookmarks bar
- Navigate to any web app → click the bookmarklet
[BrowserLens] WebSocket connected to ws://localhost:3203
[BrowserLens] DOM captured: 250 elements
[BrowserLens] Elements captured: 30
[BrowserLens] CSS vars captured: 12
[BrowserLens] Screenshot OK: 1440x900
[BrowserLens] Sync complete
Step 3 — Ask your AI agent
@browser-lens What does the header look like? Show me a screenshot.
@browser-lens What are the 2 buttons in the header? What colors are they?
@browser-lens Compare the hero section with Figma: fontSize 48px, color #ffffff, fontWeight 800
@browser-lens This button looks wrong — find the source file and suggest a fix
@browser-lens Run a full visual QA on this page
Figma Design Comparison
<div align="center"> <img src="assets/figma-comparison-flow.svg" alt="Figma Comparison Flow" width="100%"> </div>
Scoring:
| Score | Status | Meaning |
|---|---|---|
| 95–100 | match |
Pixel-perfect — ship it |
| 80–94 | minor-diff |
Close — small CSS tweaks needed |
| 50–79 | major-diff |
Significant gaps — fixes required |
| 0–49 | mismatch |
Major rework needed |
Works with any design tool — Figma, Sketch, Adobe XD, Zeplin. Just provide CSS values.
MCP Tools (30)
Live Browser Commands (2 tools) ⚡
| Tool | Description |
|---|---|
trigger_screenshot |
Request browser to take a fresh screenshot NOW — returns PNG image |
live_query_element |
Query ANY element by CSS selector in real-time — even deeply nested ones |
DOM Inspection (5 tools)
| Tool | Description |
|---|---|
get_dom_tree |
Full DOM tree with semantic structure |
inspect_element |
Complete element details: DOM + styles + layout |
query_selector |
Search DOM by tag, class, ID, or selector |
get_element_hierarchy |
Parent → child path from root to element |
get_elements_summary |
Overview of all captured elements |
CSS Analysis (4 tools)
| Tool | Description |
|---|---|
get_computed_styles |
All computed CSS properties for any element |
get_css_variables |
CSS custom properties (--*) with values |
get_typography |
Font families, sizes, weights with usage counts |
get_color_palette |
All colors (text, bg, border) with hex + count |
Layout & Spacing (3 tools)
| Tool | Description |
|---|---|
get_layout_info |
Box model, flex/grid info, positioning |
get_spacing_analysis |
Margin/padding/gap analysis + spacing scale |
get_responsive_info |
Viewport, DPR, breakpoints, media queries |
Visual & Screenshots (4 tools)
| Tool | Description |
|---|---|
get_page_screenshot |
Latest cached viewport screenshot as PNG |
get_all_screenshots |
List all captured screenshots with metadata |
describe_ui |
AI-friendly page description |
capture_screenshot_with_analysis |
Screenshot + detailed layout/style analysis |
Design Comparison (4 tools)
| Tool | Description |
|---|---|
compare_with_figma |
Compare element vs design specs → score + diff |
get_comparison_history |
All previous comparison results |
suggest_css_fixes |
Generate copy-paste CSS from comparison |
get_visual_diff_report |
Aggregate report across all comparisons |
Page Analysis (4 tools)
| Tool | Description |
|---|---|
get_full_page_analysis |
Everything in one call: structure, tokens, a11y |
get_design_tokens |
CSS variables grouped by category |
inspect_feature_area |
Inspect specific UI section with children |
get_connection_status |
Check browser connection + setup instructions |
General (4 tools)
| Tool | Description |
|---|---|
get_page_info |
Page URL, viewport, element count |
get_dom_mutations |
Recent DOM changes |
get_accessibility_info |
ARIA, roles, headings, landmarks |
clear_data |
Clear all captured data |
MCP Prompts (5) — / Commands in IDE
Type / in your IDE chat to see these guided workflows:
| Prompt | When to Use | What It Does |
|---|---|---|
/compare_with_figma |
After implementing a UI from Figma | Walks through comparing each element, generates CSS fixes |
/audit_ui |
Before PR review or release | Audits colors, typography, spacing, accessibility — rates 1-10 |
/describe_page |
When you need to explain the current UI to AI | Generates detailed page description with structure, styles, elements |
/suggest_fixes |
After running comparisons | Collects all failing comparisons + a11y issues → prioritized fix list |
/visual_qa |
Final check before shipping | Takes screenshot, compares elements, outputs PASS/NEEDS_WORK/FAIL |
Example usage in Antigravity/Cursor:
/compare_with_figma
→ AI reads current page data, asks for Figma specs, runs comparisons, suggests fixes
/audit_ui
→ AI analyzes colors (too many?), typography (consistent?), spacing (scale?), a11y (issues?)
MCP Resources (12) — @ References in IDE
Type @mcp:browser-lens/ in your IDE to access these data sources directly:
| Resource | Shorthand | When to Use | Example |
|---|---|---|---|
dom://snapshot |
@browser-lens/dom-snapshot |
Get the full DOM tree structure | "Show me the page structure" |
dom://elements |
@browser-lens/dom-elements |
List all captured element selectors | "What elements are captured?" |
dom://mutations |
@browser-lens/mutations-log |
Check recent DOM changes | "What changed since last sync?" |
css://variables |
@browser-lens/css-variables |
Get all CSS custom properties | "What design tokens exist?" |
css://typography |
@browser-lens/css-typography |
Get font usage analysis | "What fonts are used?" |
css://colors |
@browser-lens/css-colors |
Get color palette | "What colors are on this page?" |
layout://responsive |
@browser-lens/layout-responsive |
Get viewport & breakpoints | "What breakpoint is active?" |
layout://spacing |
@browser-lens/layout-spacing |
Get spacing analysis | "Is spacing consistent?" |
visual://screenshots |
@browser-lens/visual-screenshots |
List captured screenshots | "How many screenshots exist?" |
a11y://audit |
@browser-lens/accessibility-info |
Get accessibility audit | "Any a11y issues?" |
figma://comparisons |
@browser-lens/comparison-results |
Get comparison results | "How did the last comparison go?" |
browser://page |
@browser-lens/page-info |
Get page info summary | "Is browser connected?" |
Example usage:
@browser-lens/css-colors Tell me the primary colors used on this page
@browser-lens/dom-snapshot Show me the semantic structure
@browser-lens/accessibility-info Are there any accessibility issues?
Resources vs Tools:
- Resources (
@) = Read-only data snapshots. Fast, no browser command needed. Use for quick lookups. - Tools = Actions that can query the browser live, take screenshots, compare with Figma. Use for interactive work.
Bidirectional Command System
Unlike other MCP tools that only read cached data, Browser Lens has a live command channel:
IDE → MCP Server → WebSocket → Browser Bookmarklet
↓
Execute command
↓
IDE ← MCP Server ← WebSocket ← Send result
Commands the server can send to the browser:
screenshot— Capture viewport screenshot (cross-origin images auto-replaced with placeholders)element_screenshot— Capture a specific element by CSS selectorquery_element— Inspect any element by CSS selector on-demandfullsync— Trigger a full data re-capture
Screenshots (CDP — 100% Reliable)
Screenshots use Chrome DevTools Protocol (CDP) via puppeteer-core — captures exactly what you see in the browser. No CORS issues, no CSP restrictions, works on any page.
Setup: Launch browser with remote debugging
<details open> <summary><strong>Brave Browser (Mac)</strong></summary>
/Applications/Brave\ Browser.app/Contents/MacOS/Brave\ Browser --remote-debugging-port=9222
</details>
<details> <summary><strong>Google Chrome (Mac)</strong></summary>
/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222
</details>
<details> <summary><strong>Google Chrome (Linux)</strong></summary>
google-chrome --remote-debugging-port=9222
</details>
<details> <summary><strong>Microsoft Edge (Mac)</strong></summary>
/Applications/Microsoft\ Edge.app/Contents/MacOS/Microsoft\ Edge --remote-debugging-port=9222
</details>
<details> <summary><strong>Tip: Create a shell alias</strong></summary>
# Add to ~/.zshrc or ~/.bashrc
alias brave-debug='/Applications/Brave\ Browser.app/Contents/MacOS/Brave\ Browser --remote-debugging-port=9222'
alias chrome-debug='/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222'
# Then just run
brave-debug
</details>
Verify CDP is running:
curl http://127.0.0.1:9222/json/version
# Should show: {"Browser":"Brave/...","webSocketDebuggerUrl":"ws://..."}
Screenshot tools
| Tool | What it does |
|---|---|
trigger_screenshot |
Capture full viewport — returns PNG image directly |
screenshot_element |
Capture specific element by CSS selector (e.g. header, .hero-btn) |
Screenshot fallback chain
trigger_screenshot / screenshot_element
├─ 1. CDP (puppeteer-core) ← primary, 100% reliable
├─ 2. WS command → bookmarklet → html2canvas (simple pages)
└─ 3. Return cached screenshot if available
CDP auto-scans ports 9222, 9229, 9333. Set MCP_BROWSER_LENS_CDP_PORT for custom port.
Configuration
| Variable | Default | Description |
|---|---|---|
MCP_BROWSER_LENS_PORT |
3202 |
HTTP server port |
MCP_BROWSER_LENS_WS_PORT |
3203 |
WebSocket server port |
MCP_BROWSER_LENS_CDP_PORT |
9222 |
Chrome DevTools Protocol port for screenshots |
MCP_BROWSER_LENS_STORE_PATH |
.store/browser.json |
Custom store path |
Full config example:
{
"mcpServers": {
"browser-lens": {
"command": "npx",
"args": ["-y", "browser-lens-mcp@latest"],
"env": {
"MCP_BROWSER_LENS_PORT": "3300",
"MCP_BROWSER_LENS_WS_PORT": "3301",
"MCP_BROWSER_LENS_CDP_PORT": "9222"
}
}
}
}
---
## License
MIT — see [LICENSE](LICENSE)
---
<div align="center">
<sub>Built by <a href="https://github.com/nano-step"><strong>nano-step</strong></a> — Copyright © 2026 Hoai Nho Nguyen</sub>
</div>
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。