首页/测试 & QA/vibe-check
V

vibe-check

by @vibiumdevv1.0.0
0.0(0)

Vibium CLI通过命令行自动化Chrome浏览器操作,实现网页测试、数据抓取等任务。

Browser AutomationCLI TestingWeb TestingVibiumGitHub
安装方式
npx skills add vibiumdev/vibium --skill vibe-check
compare_arrows

Before / After 效果对比

1
使用前

浏览器自动化操作复杂,需编写大量代码,效率低下。

使用后

通过Vibium CLI自动化Chrome,简化操作,提升效率。

description SKILL.md

vibe-check

Vibium Browser Automation — CLI Reference The vibium CLI automates Chrome via the command line. The browser auto-launches on first use (daemon mode keeps it running between commands). vibium go && vibium map && vibium click @e1 && vibium map Core Workflow Every browser automation follows this pattern: Navigate: vibium go Map: vibium map (get element refs like @e1, @e2) Interact: Use refs to click, fill, select — e.g. vibium click @e1 Re-map: After navigation or DOM changes, get fresh refs with vibium map Binary Resolution Before running any commands, resolve the vibium binary path once: Try vibium directly (works if globally installed via npm install -g vibium) Fall back to ./clicker/bin/vibium (dev environment, in project root) Fall back to ./node_modules/.bin/vibium (local npm install) Run vibium --help (or the resolved path) to confirm. Use the resolved path for all subsequent commands. Windows note: Use forward slashes in paths (e.g. ./clicker/bin/vibium.exe) and quote paths containing spaces. Command Chaining Chain commands with && to run them sequentially. The chain stops on first error: vibium go https://example.com && vibium map && vibium click @e3 && vibium diff map When to chain: Use && for sequences that should happen back-to-back (navigate → interact → verify). Run commands separately when you need to inspect output between steps. When NOT to chain: Don't chain commands that depend on parsing the previous output (e.g. reading map output to decide what to click). Run those separately so you can analyze the result first. Commands Discovery vibium map — map interactive elements with @refs (recommended before interacting) vibium map --selector "nav" — scope map to elements within a CSS subtree vibium diff map — compare current vs last map (see what changed) Navigation vibium go — go to a page vibium back — go back in history vibium forward — go forward in history vibium reload — reload the current page vibium url — print current URL vibium title — print page title Reading Content vibium text — get all page text vibium text "" — get text of a specific element vibium html — get page HTML (use --outer for outerHTML) vibium find "" — find element, return @e1 ref (clickable with vibium click @e1) vibium find "" --all — find all matching elements → @e1, @e2, ... (--limit N) vibium find text "Sign In" — find element by text content → @e1 vibium find label "Email" — find input by label → @e1 vibium find placeholder "Search" — find by placeholder → @e1 vibium find testid "submit-btn" — find by data-testid → @e1 vibium find xpath "//div[@class]" — find by XPath → @e1 vibium find alt "Logo" — find by alt attribute → @e1 vibium find title "Settings" — find by title attribute → @e1 vibium find role — find element by ARIA role → @e1 (--name for accessible name filter) vibium eval "" — run JavaScript and print result (--stdin to read from stdin) vibium count "" — count matching elements vibium screenshot -o file.png — capture screenshot (--full-page, --annotate) vibium a11y-tree — accessibility tree (--everything for all nodes) Interaction vibium click "" — click an element (also accepts @ref from map) vibium dblclick "" — double-click an element vibium type "" "" — type into an input (appends to existing value) vibium fill "" "" — clear field and type new text (replaces value) vibium press [selector] — press a key on element or focused element vibium focus "" — focus an element vibium hover "" — hover over an element vibium scroll [direction] — scroll page (--amount N, --selector) vibium scroll into-view "" — scroll element into view (centered) vibium keys "" — press keys (Enter, Control+a, Shift+Tab) vibium select "" "" — pick a dropdown option vibium check "" — check a checkbox/radio (idempotent) vibium uncheck "" — uncheck a checkbox (idempotent) Mouse Primitives vibium mouse click [x] [y] — click at coordinates or current position (--button 0|1|2) vibium mouse move — move mouse to coordinates vibium mouse down — press mouse button (--button 0|1|2) vibium mouse up — release mouse button (--button 0|1|2) vibium drag "" "" — drag from one element to another Element State vibium value "" — get input/textarea/select value vibium attr "" "" — get HTML attribute value vibium is visible "" — check if element is visible (true/false) vibium is enabled "" — check if element is enabled (true/false) vibium is checked "" — check if checkbox/radio is checked (true/false) vibium is actionable "" — check if element is actionable (true/false) Waiting vibium wait "" — wait for element (--state visible|hidden|attached, --timeout ms) vibium wait url "" — wait until URL contains substring (--timeout ms) vibium wait load — wait until page is fully loaded (--timeout ms) vibium wait text "" — wait until text appears on page (--timeout ms) vibium wait fn "" — wait until JS expression returns truthy (--timeout ms) vibium sleep — pause execution (max 30000ms) Capture vibium screenshot -o file.png — capture screenshot (--full-page, --annotate) vibium pdf -o file.pdf — save page as PDF Dialogs vibium dialog accept [text] — accept dialog (optionally with prompt text) vibium dialog dismiss — dismiss dialog Emulation vibium viewport — get current viewport dimensions vibium viewport — set viewport size (--dpr for device pixel ratio) vibium window — get OS browser window dimensions and state vibium window [x] [y] — set window size and position (--state) vibium media — override CSS media features (--color-scheme, --reduced-motion, --forced-colors, --contrast, --media) vibium geolocation — override geolocation (--accuracy) vibium content "" — replace page HTML (--stdin to read from stdin) Frames vibium frames — list all iframes on the page vibium frame "" — find a frame by name or URL substring File Upload vibium upload "" <files...> — set files on input[type=file] Recording vibium record start — start recording (--screenshots, --snapshots, --name) vibium record stop — stop recording and save ZIP (-o path) Cookies vibium cookies — list all cookies vibium cookies — set a cookie vibium cookies clear — clear all cookies Storage State vibium storage — export cookies + localStorage + sessionStorage (-o state.json) vibium storage restore — restore state from JSON file Downloads vibium download dir — set download directory Pages vibium pages — list open pages vibium page new [url] — open new page vibium page switch <index|url> — switch page vibium page close [index] — close page Debug vibium highlight "" — highlight element visually (3 seconds) Session vibium start — start a local browser session vibium start — start connected to a remote browser vibium stop — stop the browser session vibium daemon start — start background browser vibium daemon status — check if running vibium daemon stop — stop daemon Common Patterns Ref-based workflow (recommended for AI) vibium go https://example.com vibium map vibium click @e1 vibium map # re-map after interaction Verify action worked vibium map vibium click @e3 vibium diff map # see what changed Read a page vibium go https://example.com && vibium text Fill a form (end-to-end) vibium go https://example.com/login vibium map # Look at map output to identify form fields vibium fill @e1 "user@example.com" vibium fill @e2 "secret" vibium click @e3 vibium wait url "/dashboard" vibium screenshot -o after-login.png Scoped map (large pages) vibium map --selector "nav" # Only map elements in vibium map --selector "#sidebar" # Only map elements in #sidebar vibium map --selector "form" # Only map form controls Semantic find (no CSS selectors needed) vibium find text "Sign In" # → @e1 [button] "Sign In" vibium find label "Email" # → @e1 [input] placeholder="Email" vibium click @e1 # Click the found element vibium find placeholder "Search..." # → @e1 [input] placeholder="Search..." vibium find testid "submit-btn" # → @e1 [button] "Submit" vibium find alt "Company logo" # → @e1 [img] alt="Company logo" vibium find title "Close" # → @e1 [button] title="Close" vibium find xpath "//a[@href='/about']" # → @e1 [a] "About" Authentication with state persistence # Log in once and save state vibium go https://app.example.com/login vibium fill "input[name=email]" "user@example.com" vibium fill "input[name=password]" "secret" vibium click "button[type=submit]" vibium wait url "/dashboard" vibium storage -o auth.json # Restore in a later session (skips login) vibium storage restore auth.json vibium go https://app.example.com/dashboard Extract structured data vibium go https://example.com vibium eval "JSON.stringify([...document.querySelectorAll('a')].map(a => ({text: a.textContent.trim(), href: a.href})))" Check page structure without rendering vibium go https://example.com && vibium a11y-tree Remote browser vibium start ws://remote-host:9515/session vibium go https://example.com vibium map vibium stop Multi-page workflow vibium page new https://docs.example.com vibium text "h1" vibium page switch 0 Annotated screenshot vibium screenshot -o annotated.png --annotate Inspect an element vibium attr "a" "href" vibium value "input[name=email]" vibium is visible ".modal" Save as PDF vibium go https://example.com && vibium pdf -o page.pdf Eval / JavaScript vibium eval is the escape hatch for any DOM query or mutation the CLI doesn't cover directly. Simple expressions — use single quotes: vibium eval 'document.title' vibium eval 'document.querySelectorAll("li").length' Complex scripts — use --stdin with a heredoc: vibium eval --stdin <<'EOF' const rows = [...document.querySelectorAll('table tbody tr')]; JSON.stringify(rows.map(r => { const cells = r.querySelectorAll('td'); return { name: cells[0].textContent.trim(), price: cells[1].textContent.trim() }; })); EOF JSON output — use --json to get machine-readable output: vibium eval --json 'JSON.stringify({url: location.href, title: document.title})' Important: eval returns the expression result. If your script doesn't return a value, you'll get null. Always make sure the last expression evaluates to the data you want. Timeouts and Waiting All interaction commands (click, fill, type, etc.) auto-wait for the target element to be actionable. You usually don't need explicit waits. Use explicit waits when: Waiting for navigation: vibium wait url "/dashboard" — after clicking a link that navigates Waiting for content: vibium wait text "Success" — after form submission, wait for confirmation Waiting for element: vibium wait ".modal" — wait for a modal to appear Waiting for page load: vibium wait load — after navigation to a slow page Waiting for JS condition: vibium wait fn "window.appReady === true" — wait for app initialization Fixed delay (last resort): vibium sleep 2000 — only when no better signal exists (max 30s) All wait commands accept --timeout (default varies by command). Ref Lifecycle Refs (@e1, @e2) are invalidated when the page changes. Always re-map after: Clicking links or buttons that navigate Form submissions Dynamic content loading (dropdowns, modals) Global Flags Flag Description --headless Hide browser window --json Output as JSON -v, --verbose Debug logging Tips All click/type/hover/fill actions auto-wait for the element to be actionable All selector arguments also accept @ref from vibium map Use vibium map before interacting to discover interactive elements Use vibium map --selector to reduce noise on large pages Use vibium fill to replace a field's value, vibium type to append to it Use vibium find text / find label / find testid for semantic element lookup (more reliable than CSS selectors) Use vibium find role for ARIA-role-based lookup Use vibium a11y-tree to understand page structure without visual rendering Use vibium text "" to read specific sections Use vibium diff map after interactions to see what changed vibium eval is the escape hatch for complex DOM queries vibium check/vibium uncheck are idempotent — safe to call without checking state first Screenshots save to the current directory by default (-o to change) Use vibium storage / vibium storage restore to persist auth across sessions Weekly Installs192Repositoryvibiumdev/vibiumGitHub Stars2.7KFirst SeenFeb 9, 2026Security AuditsGen Agent Trust HubPassSocketPassSnykFailInstalled onopencode179codex173gemini-cli173github-copilot170kimi-cli166amp166

forum用户评价 (0)

发表评价

效果
易用性
文档
兼容性

暂无评价,来写第一条吧

统计数据

安装量0
评分0.0 / 5.0
版本1.0.0
更新日期2026年3月18日
对比案例1 组

用户评分

0.0(0)
5
0%
4
0%
3
0%
2
0%
1
0%

为此 Skill 评分

0.0

兼容平台

🔧Claude Code

时间线

创建2026年3月18日
最后更新2026年3月18日