Loading...
Loading...
Skyline 滚动控制 API 技能。涵盖 ScrollViewContext(程序化下拉刷新、下拉二级、滚动定位)、DraggableSheetContext(半屏面板程序化滚动)、worklet.scrollViewContext(UI 线程直接控制滚动)。适用于程序化触发刷新/二级、控制 DraggableSheet 位置、在 worklet 中操作滚动。触发关键词:ScrollViewContext、DraggableSheetContext、scrollTo、triggerRefresh、triggerTwoLevel、下拉刷新API、下拉二级API、滚动API、worklet scrollViewContext。
npx skill4agent add wechat-miniprogram/skyline-skills skyline-scroll-api| API 族群 | 获取方式 | 线程 | 最低基础库 |
|---|---|---|---|
| ScrollViewContext | | 逻辑线程 | 2.14.4 |
| DraggableSheetContext | | 逻辑线程 | 3.2.0 |
| worklet.scrollViewContext | | UI 线程 | 3.3.0 |
// ScrollViewContext(需开启 enhanced)
wx.createSelectorQuery().select('#scrollview').node()
.exec(res => { const ctx = res[0].node })
// DraggableSheetContext
wx.createSelectorQuery().select('.sheet').node()
.exec(res => { const ctx = res[0].node })
// worklet.scrollViewContext(通过 ref)
this.scrollRef = wx.worklet.shared()
this.createSelectorQuery().select('.scrollable')
.ref(res => { this.scrollRef.value = res.ref }).exec()references/| 我想要... | 查阅文档 |
|---|---|
| 查看 ScrollViewContext 全部方法和属性 | |
| 了解 DraggableSheetContext.scrollTo 参数 | |
| 在 worklet 中控制滚动 | |
| 查看完整代码模式(刷新、二级、Sheet 控制) | |
enhanced<!-- ❌ 错误:未开启 enhanced,node() 返回的不是 ScrollViewContext -->
<scroll-view type="list" scroll-y>
<!-- ✅ 正确 -->
<scroll-view type="list" scroll-y enhanced>// ❌ 错误:同时传入 size 和 pixels,pixels 被忽略
sheetContext.scrollTo({ size: 0.7, pixels: 200 })
// ✅ 正确:二选一
sheetContext.scrollTo({ size: 0.7 }) // 相对位置
sheetContext.scrollTo({ pixels: 200 }) // 绝对位置NodesRef.ref// ❌ 错误:使用 node() 而非 ref()
this.createSelectorQuery().select('.scroll').node()
.exec(res => { /* 这是 ScrollViewContext,不是 worklet 引用 */ })
// ✅ 正确:使用 ref() + shared()
this.scrollRef = wx.worklet.shared()
this.createSelectorQuery().select('.scroll')
.ref(res => { this.scrollRef.value = res.ref }).exec()'worklet'// ❌ 错误:缺少 worklet 指令
onTap() {
scrollViewContext.scrollTo(this.scrollRef.value, { top: 200 })
}
// ✅ 正确
onTap() {
'worklet'
scrollViewContext.scrollTo(this.scrollRef.value, { top: 200 })
}worklet.scrollViewContext.scrollToworklet.scrollViewContext.scrollTo| 方法 | 说明 | 最低基础库 |
|---|---|---|
| 滚动至指定位置 | 2.14.4 |
| 滚动至指定元素 | 2.14.4 |
| 触发下拉刷新 | 3.0.0 |
| 关闭下拉刷新 | 3.0.0 |
| 触发下拉二级 | 3.0.0 |
| 关闭下拉二级 | 3.0.0 |
| 属性 | 类型 | 说明 |
|---|---|---|
| scrollEnabled | boolean | 滚动开关 |
| bounces | boolean | 边界弹性(仅 iOS) |
| showScrollbar | boolean | 显示滚动条 |
| pagingEnabled | boolean | 分页滑动 |
| fastDeceleration | boolean | 快速减速(仅 iOS) |
| decelerationDisabled | boolean | 取消滚动惯性(仅 iOS) |
| 场景 | 推荐 API |
|---|---|
| 程序化触发下拉刷新 | |
| 数据加载完成后关闭刷新 | |
| 打开/关闭下拉二级 | |
| 滚动到指定偏移量 | |
| 滚动到指定元素 | |
| 控制 DraggableSheet 位置 | |
| UI 线程中控制滚动(配合手势) | |
// 获取 ScrollViewContext
wx.createSelectorQuery().select('#sv').node().exec(res => {
const ctx = res[0].node
ctx.triggerRefresh({ duration: 300 })
// 数据加载完成后
setTimeout(() => ctx.closeRefresh(), 2000)
})| 场景 | 推荐技能 | 说明 |
|---|---|---|
| scroll-view 组件属性和事件 | | scroll-view/draggable-sheet 组件详解 |
| Worklet 动画系统 | | SharedValue、timing/spring、worklet 基础 |
| 页面转场路由 | | 自定义路由、预设路由 |
| Skyline 概览与迁移 | | 渲染引擎概览、兼容性 |
references/
├── api/
│ ├── draggable-sheet-context.md
│ ├── scroll-view-context.md
│ └── worklet-scroll-context.md
└── patterns.md