本文总结一些常见的用户交互体验优化的方法
使用 loading 图或者是骨架屏,可以一定程度上减少用户等待加载的焦虑感,让用户感觉没有等太久,这就是用户体验级的优化。
PS: 可以利用 webpack 实现骨架屏的自动生成
图片懒加载是一种优化网页性能的技术,它通过延迟加载页面上的图片,直到图片进入用户视野(可见区域)时才进行加载。这有助于减少页面加载时间,特别是在包含大量图片的长页面上。
基本原理如下:
-
页面初次加载时,只加载可见区域内的图片,而对于在用户当前视野之外的图片,不提前加载。
-
当用户滚动页面,当图片进入可见区域时,通过 JavaScript 触发图片的加载,从而实现逐步加载。
在这个示例中,使用 data-src 属性保存图片的真实 URL,而 src 属性则设置一个占位图像或加载中的图像。使用 JavaScript 检测滚动事件,当图片进入可见区域时,将 data-src 的值赋给 src,触发实际的图片加载。
完整的 demo 请看 👉 在线效果预览, 查看示例代码请点击此处
只有在用户滚动到可见范围内时,才会渲染和呈现列表项。这可以通过监听滚动事件,计算当前可见的列表项,然后仅渲染这些项来实现。
社区中有很多现成的组件可以使用,比如 react-virtualized, vue-virtual-scroller 等
可以参考 防抖节流
直接操作 DOM,有可能会引起大面积的重排和重绘,从而引起掉帧的情况,导致用户体验下降。
合理使用 CSS3 GPU 加速,可以避免使用动画之后的重排和重绘,达到更流畅的动画效果。
- 展开收起过渡动画效果: 下拉组件可以添加过渡动画,让用户感觉更加流畅
图片加载失败,点击刷新重新加载图片的实现逻辑无非就是,点击刷新的时候往图片 url 追加时间戳。
let imgUrl = "http://example.com/img.png";
const currentTime = +new Date();
imgUrl = `${imgUrl}?${currentTime}`;