首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

小程序 tab 滚动列表优化方案

类似于今日头条资讯切换列表 今天在做百度小程序的转换,发现真机上用之前的swiper-item结合scroll-view 实现的Tab列表的效果不理想,于是我重新思考,发现了一种更合适的方案。...这样导致了我每次切换到另外一个swiper-item时要计算他的滚动位置和他的全部元素高度。 我还需要频繁记录每次滚动的定位,保存起来,以便下次用的时候来拿,使用scroll事件很卡。...,内容已经生成了,但是位置没有定位,要等零点几秒才能定位到那个位置,就是说你能看到内容在从头滚动。...这样子就避免了切换时历史滚动位置需要重置的问题。于是我想到了既然用他这种做法解决了我前面的缺陷,那我把两个结合起来,不就完美解决了。...list[cid].pageNo < list[cid].pageCount) { self.getList(cid); } }, 300); }, //请求列表

2K10
您找到你想要的搜索结果了吗?
是的
没有找到

详解Android 视频滚动列表(偷懒型)

公司的项目需要一个视频的滚动列表。 搜了些文章比较常见的是根据列表项的可视百分比来判断的。实现起来略复杂。...这里想了一个在要求不高的情况下,实现相对简便的方法:根据列表滚动时可见的第一个列表项的位置来播放和暂停对应列表项内的视频。 它的效果大致是这样的: ? 以下是它的实现。 首先当然是建立列表。...这部分就直接用ListView吧,列表的具体的实现就不贴了。大致就是长这样的一个列表: ? 接下来就是添加播放器。 这里需要注意的是,在ListView里不能使用我们常用的那种VideoView。...接下来就是重点了,要根据列表滚动来播放和暂停视频。 这里根据当前滚动的位置来进行判断。...这个其实应该根据滚动方向和item的高度来计算的。

89820

记一次 「 无限滚动列表优化

如图所示: 快速滚动出现空白 作为对比,看一下优化后的效果: 优化之后 问题定位 在chrome调试工具下,边拖动列表边观察dom的变化。...首先,原来无限滚动的逻辑就是基于scroll事件,通过不断滚动触发的回调,重新计算渲染到页面上的区间。 其次,为了动态调整可视区域的元素,使用了MutationObserver。...用户往下滚动时,observer-dom元素“出现”在用户视野。 每次多加载一屏的数据,循环如此,直到整个列表都渲染到页面上。...---- 总结 通常,无限滚动的方案可以分为两种: 1....虚拟长列表 优点:可以保证渲染在页面上的dom元素尽可能少 缺点:如果没有特殊处理(比如rc或锁定滚动区域),快速滚动时,基本都会有闪动的情况(也就是本次的空白问题) 2.

3.2K20

仿腾讯课堂固定滚动列表ReactNative组件

前言 由于业务需要做成类似腾讯课堂课程详情滚动的效果,考虑到后面有可能有新的呈现方式,RN提供的组件没有这种滚动控件,不如自己封装,其实去年已经写了一篇但是写的比较乱,周末花了点时间重写梳理下做的东西。...跑起来运行后发现的一个严重的问题是,如果Tab导航控件的内容区域存在ScrollView或者ListView时,无法滚动,只有最外层可以滚动,也就是手势滚动被拦截了?...+手势往上则通知内层滚动容器开始滚动;内层到顶部+手势往下则通知外层开始滚动。...一个是怎么判断手势滑动以及外层滚动容器到底部和内层滚动到顶部? 第二个是寻找滚动组件并通知内层滚动组件开始滚动?...回过头来讲外层滚动容器通知内层滚动,其实通知滚动相当于不拦截事件,那么就是重写 onInterceptTouchEvent方法并返回false。而这个方法会随着手势不断调用,这时候聪明的你想到了啥?

4.8K70

jquery scroll 滚动加载列表 获取腾讯云图片像素信息

jquery scroll 滚动加载列表 获取腾讯云图片像素信息 场景描述 问题处理 其他问题处理 场景描述 bootstarp列表加载图片时需要同时获取图片的像素(宽and高),对于腾讯云这类远程存储获取图片来说...,虽然也可以通过java后台调用腾讯云接口获取图片像素,但是在列表加载大量图片并且没有分页的情况下,如果通过后台逐个获取图片像素信息返回给前台页面渲染的话,会导致前台页面迟迟加载不出来,且有浏览器内存耗尽卡死的风险...问题处理 首先找到前端同事帮忙写一下scroll方法的加载结构和页面热区的宽高计算,然后补充具体参数信息及业务逻辑信息 列表html结构如下 代码如下 var start = function() {...,待滚动鼠标时再拉去当前页面热区内未加载图片像素信息的图片像素 其他问题处理 由于业务需要,除了列表页,我们同时增加了视图模式,效果如图 列表增加了滚动加载图片像素信息的方法,那么视图模式同样也需要,视图代码结构...,因为不销毁的话,在列表模式下,滚动的话也会执行视图模式的滚动方法导致资源浪费,关闭滚动方法的处理如下 //切换列表和块的方法 function toggleCustomView(){ if($('

6810

Vue2.0 歌手列表滚动及右侧快速入口实现

WebApp Vue2.0 路由配置及Tab组件开发 Vue2.0 数据抓取及Swiper组件开发 Vue2.0 scroll 组件的抽象和应用 Vue2.0 歌手数据获取及排序 Vue2.0 歌手列表滚动及右侧快速入口实现...$refs.listGroup[index], 0) } } } 3 右侧快速入口_滑动滚动 当我们的手指在右侧快速入口上滑动时,歌手列表也会同步进行滚动,当我们滚动右侧快速入口时...,我们需要阻止歌手列表滚动,以及浏览器原生滚动,所以要使用@touchmove.stop.prevent阻止冒泡,并且在onShortcutTouchStart事件中记录触碰点的初始位置,以及onShortcutTouchMove...} }, components: { Scroll } } 4 右侧快速入口_高亮设置 当歌手列表滚动时...当我们滚动歌手列表页时,希望该歌手的title一直显示在顶部,并且滚动到下一个title时,新的title将旧的title顶替掉,这里就需要我们计算一个title的高度 // listview.vue

74850

Android开发实现横向列表GridView横向滚动的方法【附源码下载】

本文实例讲述了Android开发实现横向列表GridView横向滚动的方法。分享给大家供大家参考,具体如下: Android 横向列表实现,可左右滑动,如下图 ? 1....主界面布局代码:activity_main.xml a.包裹HorizontalScrollView控件是GirdView横向滚动的基本条件 b.GirdView外包裹LinearLayout是java...spacingWidthUniform" </GridView </LinearLayout </HorizontalScrollView </LinearLayout 2.主界面GridView列表子项布局文件...gridView.setLayoutParams(params); // 设置GirdView布局参数,横向布局的关键 gridView.setColumnWidth(itemWidth); // 设置列表项宽...(size); // 设置列数量=列表集合数 GridViewAdapter adapter = new GridViewAdapter(getApplicationContext(), cityList

2.4K10
领券