Install
openclaw skills install user-test-toolkit为Vibe Coding页面无侵入自动采集用户操作轨迹及行为,支持嵌入任务引导、微问卷和多项标准量表,适用可用性测试与用户研究。
openclaw skills install user-test-toolkit<!-- 1. 引入配置 + 设置你的产品信息 -->
<script src="survey-config.js"></script>
<script>
window.SURVEY_CONFIG = {
productName: '我的产品',
tasks: [
{ id:'T1', label:'完成注册', detect:'signup_done' },
{ id:'T2', label:'完成下单', detect:'order_done' },
{ id:'T3', label:'完成支付', detect:'payment_done' }
]
};
</script>
<!-- 2. 引入核心文件 -->
<script src="tracker.js"></script>
<script src="survey.js"></script>
// 用户完成某个步骤时调用一次,Survey 自动响应
UserTestTracker.milestone('signup_done'); // 注册完成 → 触发 T1 任务
UserTestTracker.milestone('order_done'); // 下单完成 → 触发 T2 任务
UserTestTracker.milestone('payment_done'); // 支付完成 → 触发 T3 + 总结问卷
| 模块 | 功能 | 定制方式 |
|---|---|---|
| tracker.js | 6 维埋点(操作/犹豫/困惑/停留/里程碑/热区) | 改 TRACKER_CONFIG.endpoint 即可 |
| survey.js | 主动问卷(任务面板 + checkpoint 微问卷 + SUS/EV/NPS) | 改 SURVEY_CONFIG.tasks 即可 |
<script src="tracker-config.js"></script>
<script>
// ★ 必须设置:数据上报地址
window.TRACKER_CONFIG.endpoint = 'https://your-server.com/track';
// ★ 推荐设置:milestone 映射(让 survey.js 能跨产品工作)
window.TRACKER_CONFIG.milestones = {
'signup_done': 'step1_done',
'order_complete':'step2_done',
'payment_done': 'task_done'
};
// ★ 可选:自定义 action 识别
window.TRACKER_CONFIG.actionMap = {
'.signup-btn': 'signup',
'#checkout-btn':'purchase',
'.play-btn': 'play_video'
};
</script>
<script src="tracker.js"></script>
<script src="survey-config.js"></script>
<script>
// ★ 推荐设置:产品名称(用于问卷文案)
window.SURVEY_CONFIG.productName = '我的产品';
// ★ 必须设置:任务列表(核心定制点)
window.SURVEY_CONFIG.tasks = [
{ id:'T1', label:'完成注册流程', detect:'step1_done' },
{ id:'T2', label:'完成首次下单', detect:'step2_done' },
{ id:'T3', label:'完成支付', detect:'task_done' }
];
// ★ 推荐设置:情境问卷(checkpoint)
window.SURVEY_CONFIG.checkpoints = [
{
id: 'signup_ease',
trigger: 'step1_done',
delay: 1500,
type: 'rating',
question: '注册流程顺利吗?',
scale: 5,
labels: ['很困难', '有点绕', '还行', '比较顺', '一下就找到了'],
allowComment: true,
commentPH: '在哪卡住过?(可选)'
}
];
</script>
<script src="survey.js"></script>
// 业务完成某个步骤时调用一次,Survey 自动响应
UserTestTracker.milestone('signup_done'); // 注册完成 → 触发 T1 任务 + 对应 checkpoint
UserTestTracker.milestone('step2_done'); // 下单完成
UserTestTracker.milestone('task_done'); // 支付完成 → 触发 T3 + 任务结束 + 总结问卷
user-test-toolkit/
├── SKILL.md # 本文档
├── references/
│ ├── tracker-spec.md # Tracker 完整 API 参考
│ └── survey-spec.md # Survey 配置参考 + 题型说明
└── assets/
├── tracker.js # 埋点系统(v3,支持配置)
├── tracker-config.js # Tracker 配置模板(即插即用)
├── survey.js # 问卷引擎(v3,支持配置)
└── survey-config.js # Survey 配置模板(零基础定制)
| 配置项 | 类型 | 默认值 | 说明 |
|---|---|---|---|
endpoint | string | '' | 必填。埋点上报地址,如 'https://your-server.com/track' |
flushInterval | number | 8000 | 批量上报间隔(ms) |
maxQueue | number | 30 | 缓存超过此条数立即上报 |
milestones | object | 内置映射 | milestone 名称映射表:{ 业务名: 通用名 } |
actionMap | object | {} | action 自动分类选择器映射 |
disabled | boolean | false | true = 记录但不上报 |
| 配置项 | 类型 | 默认值 | 说明 |
|---|---|---|---|
productName | string | '本产品' | 问卷文案中的产品名称 |
tasks | array | 内置默认 | 任务定义数组(见下方格式) |
checkpoints | array | 内置默认 | 情境问卷数组(见下方格式) |
welcomeInternal | object | 内置默认 | 内部测试欢迎页文案 |
welcomeUser | object | 内置默认 | 外部用户欢迎页文案 |
testVideoUrl | string | 'assets/test-video.mov' | 测试素材下载地址 |
openQuestion1/2 | string | 内置默认 | 总结问卷开放题文本 |
{
id: 'T1', // 唯一ID
label: '完成注册流程', // 显示给用户的任务描述
hint: '用手机号注册', // 内部模式显示的提示(可选)
detect: 'signup_done' // 触发的 milestone 名称(映射后)
}
// rating 型(李克特评分)
{
id: 'signup_ease',
trigger: 'signup_done', // 映射前的 milestone 名称
delay: 1500, // 延迟触发(ms)
type: 'rating',
question: '注册流程顺利吗?',
scale: 5, // 5 或 7 分
labels: ['很困难', ..., '很顺利'], // 两端标签
allowComment: true, // 是否显示评论框
commentPH: '在哪卡住过?' // 评论 placeholder
}
// sam 型(SAM 情绪模型)
{
id: 'post_use_sam',
trigger: 'task_done',
delay: 2000,
type: 'sam',
question: '使用后感觉如何?',
dims: [
{ id: 'arousal', label: '紧张程度', l: '很放松', r: '很焦虑' },
{ id: 'valence', label: '满意程度', l: '不满意', r: '很满意' }
]
}
| type | 说明 | detail 字段 |
|---|---|---|
enter | 页面访问 | url, referrer, screen, viewport |
first_interact | 首次交互 | how(click/scroll/enter_key/focus_input), hesitation(秒) |
click | 点击 | target(CSS选择器), x/y(%), action(分类名称) |
frustration | 困惑行为 | target, repeats(次数), hint |
file_select | 文件选择 | name, sizeMB, type |
focus | 输入框聚焦 | target |
input_enter | 回车提交 | inputId, length |
scroll | 滚动深度 | depth(%) |
tab_away/back | 页面切换 | elapsed(秒) |
leave | 页面离开 | duration, scrollDepth, interactions, hesitation |
error | JS 错误 | msg, file, line |
milestone | 业务里程碑 | name(映射后), originalName(映射前) |
phase_start/end | 阶段标记 | phase |
upload_progress/done/fail | 上传 | pct / url,sizeMB / error |
mps_status | MPS 状态 | status, elapsed |
survey_show/answer/skip/exit_submit | 问卷事件 | — |
task_complete | 任务完成 | taskId, label, elapsed |
// 底层
UserTestTracker.record(type, detail) // 记录任意事件
UserTestTracker.flush() // 强制刷新缓冲区
// 里程碑(最常用)
UserTestTracker.milestone(name) // 记录 milestone(自动映射)
UserTestTracker.milestone(name, extra) // 带附加数据
// 阶段
UserTestTracker.phaseStart(name)
UserTestTracker.phaseEnd(name)
// 上传
UserTestTracker.uploadProgress(pct) // 0-100
UserTestTracker.uploadDone(url, sizeMB)
UserTestTracker.uploadFail(err)
// MPS 状态(保留给特定场景)
UserTestTracker.mpsStatus(status, elapsed)
// 问卷联动(Survey 内部使用)
UserTestTracker.surveyShow(id, type)
UserTestTracker.surveyAnswer(data)
UserTestTracker.surveySkip(id)
UserTestTracker.surveyExitSubmit(data)
UserTestTracker.taskComplete(taskId, label)
// 信息
UserTestTracker.uid // 当前用户 ID
UserTestTracker.testRound // 当前测试轮次
UserTestTracker.sessionId // 当前会话 ID
assets/test-video.movTRACKER_CONFIG.endpoint + SURVEY_CONFIG.tasks?uid=user001&test=round1&smode=teststype=user)/track 端点汇总tracker.js,不引 survey.jssmode=test 参数| 输出 | 来源 | 内容 |
|---|---|---|
| 操作序列JSON | tracker | 完整用户行为路径(时间线) |
| 犹豫/困惑标记 | tracker | 入口问题 + 困惑点定位 |
| 里程碑转化率 | tracker | 核心漏斗各步骤到达率 |
| SUS 评分 | survey exit | 可用性量化分(0-100) |
| NPS 评分 | survey exit | 推荐意愿(-100~100) |
| EV 情绪分 | survey exit | 9题情绪价值均值 |
| 三词标签 | survey exit | 用户心智关键词 |
| 开放反馈 | survey exit | 定性问题和建议 |
cd ~/.codebuddy/skills/user-test-toolkit
git init
git add .
git commit -m "feat: user-test-toolkit v3 configurable"
git remote add origin https://github.com/YOUR_USERNAME/user-test-toolkit.git
git push -u origin main
其他人使用:
git clone https://github.com/YOUR_USERNAME/user-test-toolkit.git
# 或作为 submodule