flutter - 如果有很多要滑动的项目,滑块会挂起
问题描述
我有大约 10000 个项目的水平列表,并且滚动我使用的是颤振滑块,但它根本不平滑。我认为在换向阀上设置状态不是正确的方法。
Slider(
key: ValueKey('slider'),
activeColor: Colors.blue,
inactiveColor: Colors.white,
min: 0.0,
max: scrollController.hasClients
? scrollController
.position.maxScrollExtent
: 10000.0,
value: value,
onChanged: (double value) {
scrollController.position
.jumpTo(value);
if (mounted)
setState(
() => this.value = value);
},
onChangeStart: (double value) {},
onChangeEnd: (double value) {
},
)```
解决方案
以下是一些使其更快的提示:
- 而不是使用
min: 0.0
andmax: 10000.0
您可以保留默认值从 to 工作0.0
,1.0
然后乘以value * 10000.0
,这样Slider
就不必计算 from0.0
to10000.0
但 from0.0
to 的值的位置1.0
。 - 如果
setState()
只更新Slider
而不是整个小部件树,那就太好了。为此,您可以将Slider
a放入StatefulWidget
,或者您可以将 a 包裹Slider
起来StatefulBuilder
。 - 在模式下运行应用程序
release
将比在debug
模式下更快。
这是一个简单的示例,使用StatefulBuilder
:
StatefulBuilder(
builder: (context, setState) {
return Slider(
value: value,
onChanged: (value) {
_scrollController.position.jumpTo(value * 10000);
setState(() {
this.value = value;
});
},
);
},
)
推荐阅读
- java - 使用 FFMPEG 流式传输原始声音
- python - 为什么这个类使用“self”作为位置参数?
- javascript - 每个测试文件的 Karma 运行时
- html - 如何将 div 居中,同时将 div 内的内容保持在原位
- reactjs - 如何使用 React Router 混合使用父子路由正确路由
- r - modCost 中的错误(obs = world_data,model = out):在 R 中找不到对象“world_data”
- python - 计算余弦相似度:ValueError: Input must be 1- or 2-d
- jboss - PersistenceException / HibernateException:事务在不同的线程中回滚
- python - int() 参数必须是字符串、类似字节的对象或数字,而不是 'NoneType' Django 表单
- laravel - 如何在windows中输入php artisan serve linux?