develop-userscripts
Goアーキテクトのペルソナ。簡潔さと明示性を推奨し、実際の問題を解決する場合にのみデザインパターンを適用し、時期尚早な抽象化に反対。
npx skills add xixu-me/skills --skill develop-userscriptsBefore / After 効果比較
1 组Goのコード構造を設計する際、過度に抽象化しやすく、パターンのためにパターンを適用し、不必要な複雑さを導入し、理解と保守のコストを増加させる。
Goの簡潔なスタイルを維持するよう導き、本当に必要な場合にのみデザインパターンを適用し、明示性と可読性を優先し、不必要な抽象化の階層を減らす。
description SKILL.md
develop-userscripts
Userscript work usually breaks at the runtime and metadata boundary, not in the page logic. Choose the runtime first, declare the minimum permissions up front, then debug in the environment where the script actually runs.
When to Use
Use this skill for:
-
writing or fixing a Tampermonkey or ScriptCat userscript
-
debugging injection timing, missing permissions, CSP workarounds, update checks, or
GM_*behavior -
deciding between a portable foreground script and ScriptCat-only
@backgroundor@crontab -
adding config UI with
==UserConfig== -
packaging a ScriptCat
==UserSubscribe==bundle or preparing a CloudCat-compatible script
Do not use this skill for full browser extension development or general browser automation outside userscript managers.
Runtime Selection
digraph userscript_runtime {
"Need page DOM or page context?" [shape=diamond];
"Need persistent or scheduled work?" [shape=diamond];
"Need to install many scripts as one package?" [shape=diamond];
"Portable foreground script" [shape=box];
"ScriptCat background or crontab script" [shape=box];
"ScriptCat subscription package" [shape=box];
"Need page DOM or page context?" -> "Portable foreground script" [label="yes"];
"Need page DOM or page context?" -> "Need persistent or scheduled work?" [label="no"];
"Need persistent or scheduled work?" -> "ScriptCat background or crontab script" [label="yes"];
"Need persistent or scheduled work?" -> "Need to install many scripts as one package?" [label="no"];
"Need to install many scripts as one package?" -> "ScriptCat subscription package" [label="yes"];
"Need to install many scripts as one package?" -> "Portable foreground script" [label="no"];
}
Preflight
-
Confirm the manager and browser. On Manifest V3 browsers, ScriptCat may require
Allow User Scriptsor browser developer mode before scripts run. -
Decide page script versus background script before writing code. ScriptCat background scripts cannot touch the DOM.
-
Start with metadata, not implementation:
@match,@grant,@connect,@run-at, and any update URLs. -
Prefer portable
==UserScript==patterns for ordinary page scripts. Only switch to ScriptCat-only headers when the requested behavior actually needs them.
Workflow
-
Choose the runtime and metadata first.
-
Declare the smallest permission surface that fits the task.
-
Implement against the runtime you chose.
-
Debug where the code really runs.
Foreground scripts: page console plus manager logs.
-
ScriptCat background scripts: run log first, then
background.htmlfor real-environment debugging. -
Publish with the right update model.
Normal scripts: keep @version accurate and add @updateURL or @downloadURL only when needed.
- Subscription bundles: use
==UserSubscribe==, HTTPS URLs, and subscription-level@connect.
Quick Reference
Intent Default choice Watch for
Page UI, DOM scraping, page patching
Portable ==UserScript==
@match, @grant, @run-at, CSP-sensitive injection
Cross-origin API access
GM_xmlhttpRequest with explicit @connect
Missing hosts, cookie behavior differences, user authorization
Long-running worker
ScriptCat @background
No DOM, must return Promise for async work
Scheduled task
ScriptCat @crontab
Only first @crontab counts, prefer 5-field cron, avoid interval overlap
User-editable settings
==UserConfig== plus GM_getValue
Block placement and group.key naming
Silent bundle install and updates
==UserSubscribe==
HTTPS, user.sub.js, subscription connect overrides child scripts
Common Mistakes
-
Missing
@grantfor APIs the script actually uses. -
Missing
@connectfor hosts used byGM_xmlhttpRequestorGM_cookie. -
Treating
@includeas a better default than@matchfor ordinary host targeting. -
Using DOM APIs inside ScriptCat background or cron scripts.
-
Returning from a ScriptCat background script before async GM work is truly finished.
-
Mixing
==UserScript==and==UserSubscribe==packaging concepts. -
Putting
==UserConfig==in the wrong place or reading config keys without thegroup.keyname. -
Assuming Tampermonkey and ScriptCat storage, notification, or request behavior is identical.
References
Weekly Installs1.8KRepositoryxixu-me/skillsGitHub Stars29First Seen2 days agoSecurity AuditsGen Agent Trust HubPassSocketPassSnykWarnInstalled onopencode1.8Kcodex1.8Kkimi-cli1.8Kdeepagents1.8Kantigravity1.8Kgemini-cli1.8K
forumユーザーレビュー (0)
レビューを書く
レビューなし
統計データ
ユーザー評価
この Skill を評価