分享滚动加载的第三方库

1 引言

在写页面的时候会经常用到滚动加载,有时会花费很长的时间去挑选尝试npm上的哪个库会比较适合自己的要求,为了节省大家的时间,简单介绍几个库,可以方便大家使用。

2 简介

下面就是一些库的效果展示了,以动态图的方式展现,可以更好的理解这些库的效果。

React Lazy Load Image Component

先是图片的懒加载

这个是当加载 src 中指定的图像时,基于并转换为彩色图像呈现黑白图像。
在这里插入图片描述
当加载 src 中指定的图像时,渲染基于并转换为非模糊图像的模糊图像。
在这里插入图片描述
在加载图像时呈现空白区域并转换为完全不透明。
在这里插入图片描述

import React from 'react';
import {
    LazyLoadImage } from 'react-lazy-load-image-component';
 
const MyImage = ({
     image }) => (
  <div>
    <LazyLoadImage
      alt={
   image.alt}
      height={
   image.height}
      src={
   image.src} // use normal <img> attributes as props
      width={
   image.width} />
    <span>{
   image.caption}</span>
  </div>
);
 
export default MyImage;

三种效果可以满足一般的需求

它还可以做到延迟加载

当您在同一页面中有许多元素要延迟加载时,您的性能可能会很差,因为每个元素都在监听滚动/调整大小事件。在这种情况下,最好用 HOC 包装这些组件的最深公共父级以跟踪这些事件
在这里插入图片描述

import React from 'react';
import {
    LazyLoadImage, trackWindowScroll }
  from 'react-lazy-load-image-component';
 
const Gallery = ({
     images, scrollPosition }) => (
  <div>
    // We are loading landscape.jpg here
    <img src="/landscape.jpg" alt="Beautiful landscape" />
    {
   images.map((image) =>
      <LazyLoadImage
        key={
   image.key}
        alt={
   image.alt}
        scrollPosition={
   scrollPosition}
        src={
   image.src}
        // If the image we are creating here has the same src than before,
        // we can directly display it with no need to lazy-load.
        visibleByDefault={
   image.src === '/landscape.jpg'} />
    )}
  </div>
);
 
export default trackWindowScroll(Gallery);

当然,他可以做到组件的懒加载,但是效果一般,不推荐使用。

import React from 'react';
import {
    LazyLoadComponent } from 'react-lazy-load-image-component';
import {
    ArticleContent, ArticleComments }
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个集成目前Android主流优秀第三方组件、优秀好用的自定义控件、实用工具类封装、以及一些APP共通模块(比如:版本更新、意见反馈、引导界面等等)的开发包,帮助程序员快速开发自己的APP 已集成第三方开源组件: 网络请求android-async-http 图片异步加载universal-image-loader Sqlite数据操作ormlite-android 社会化分享ShareSDK+短信验证码 Zxing二维码 百度地图定位SDK 谷歌依赖注入RoboGuice WebService调用ksoap2 XML解析XStream 动画开源nineoldandroids 表单验证android-validation-komensky 更多优秀开源等待集成... 已封装工具类: HTTP网络通信工具类(ToolHTTP.java),get/post请求,支持多种接口回调 SOAP协议通信工具类(ToolSOAP.java),基于异步回调请求WebService接口 Sqlite数据操作工具类(ToolDatabase.java),获取DAO、创建表、删除表等API 提示信息对话框工具类(ToolAlert.java),已集成泡泡、土司、对话框三种提示 文件操作工具类(ToolFile.java),assets/raw/xml/shrePerface/等文件读写API 地图定位工具类(ToolLocation.java),读取GPS状态、请求定位、获取经纬度等方法 社会化分享工具类(ToolShareSDK.java),各大开发平台分享API操作 短信验证码工具类(ToolMSM.java),移动/联通/电信三网发送手机短信验证码、异步回调验证结果 字符串操作工具类(ToolString.java),生成UUID、非空非NULL逻辑判断、生成MD5等常用共通方法 数据操作工具类(ToolData.java),自动递归获取表单数据封装成Map、本地数据分页共通方法等 图片操作工具类(ToolPicture.java),生成二维码、验证码、灰度、合成、圆角、水印等操作 读取本地资源工具类(ToolResource.java),反射本地资源文件API,避免依赖R文件,方便jar形式发布 Android单位转换工具类(ToolUnit.java),sp/dp/px互转 自定义Toast工具类(ToolToast.java),自定义背景色、字体颜色、大小、边框等 Properties操作工具类(ToolProperties.java),读写Properties文件操作 网络操作工具类(ToolNetwork.java),获取网络信息、更改切换网络等相关操作 日期操作工具类(ToolDateTime.java),获取日期、日期加减、格式化日期、日期转换等操作 XML操作工具类(ToolXml.java),基于DOM/XMLPullPaser模式解析、生成XML操作 XMPP操作工具类(ToolXMPP.java),基于XMPP协议的相关API操作 适配字体工具类(ToolAutoFit.java),代码根据设备密度自动缩放View的字体大小 LOG相关工具类(ToolLog.java) 功能待续-->切入记录异常日志,并存储文件或上传至服务器 已封装/收集自定义控件: 兼容低版本的SwitchButton 追加自定义属性Value的CheckBox/RadioButton/RadioGroup/SingleSpinner 圆角提示信息TipsView 圆角图片RoundImageView 自定义样式风格ProgressDialog 自定义样式WebView 圆形进度条(RoundProgressBar)、垂直进度条(VerticalProgressBar) 开源优秀自定义控件:imageindicator(图片轮播/引导界面)、pulltorefresh、XListView、TableFixHeaders(水平+垂直滚动+首行+首列冻结表格)、ViewPager

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值