作者:萱萱loveTFOOYS | 来源:互联网 | 2023-09-11 12:46
副标题—-为何我要写这个react插件图片懒加载是项目中经常运用的功用,但是现有react懒加载组件库,用着都不是很爽了?。归纳综合一下有以下几点:没有只针对image懒加载组件。
副标题—-为何我要写这个 react 插件
图片懒加载是项目中经常运用的功用,但是现有 react 懒加载组件库,用着都不是很爽了 ?。归纳综合一下有以下几点:
- 没有只针对 image 懒加载组件。多半组件库都内置了模块、组件、剧本、iframe 懒加载功用,而弱化了 image 懒加载功用。
- 不支撑动画显现结果。
- 不天真,可设置度不高。
- placeholder 不能组件化。
- 不支撑相应式图片( picture / srcset )。
react-lazyimg-component
清晰本身想要什么样的组件,就本身着手撸呗 ?。因而乎,react-lazyimg-component 就诞生了 ?。我们先来看看它的结果吧:
singsong: 假如人人有时间,窝照样勉励人人本身着手完成一些小插件。
用力猛击这里
什么情况须要运用它
1. 玲珑轻巧,简朴易用,基本无进修本钱
在谁人 jQuery 金瓯无缺的年代,撸代码就用 jQuery 一把梭。个中
jQuery.lazyload 是一个很经常运用图片懒加载插件。 能够许多像我一样的小伙伴们,懒加载就直接上 jQuery.lazyload,早已习惯了 jQuery.lazyload 运用。 因而本身就揣摩可否继续 jQuery.lazyload 运用方法同时坚持 react 特有组件特征。如许能够很快上手~?
singsong: 这里只是继续了 jQuery.lazyload 设置特征,不是完整继续。毕竟 jQuery 与如今主流的 MVVM 框架头脑判然不同。
假如小伙伴们熟习 jQuery.lazyload , 完整没有进修本钱直接上手 react-lazyimg-component 哈。 只说不是写,然并卵。那我们来看看它究竟好用不:
装置
// npm
$> npm install react-lazyimg-component
// yarn
$> yarn add react-lazyimg-component
运用
// 引入
import Lazyimg, { withLazyimg } from 'react-lazyimg-component';
// 挪用
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
是否是很简朴,有木有 ?。上述只是运用 react-lazyimg-component 的默许设置。 这里我们能够经由过程设置项来定制懒加载的行动:
// 引入 lazyimg
import Lazyimg, { withLazyimg } from 'react-lazyimg-component';
// 引入 volecity.js
import 'velocity-animate';
import 'velocity-animate/velocity.ui';
// 设置
const cOnfig= {
threshold: 100, // 指定触发阈值
js_effect: 'transition.fadeIn', // 支撑 velocity.js 动画结果
};
// 基于设置项天生对应 Lazy 组件
const Lazy = withLazyimg(config);
// 挪用
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
接下来我们来看看 react-lazyimg-component 都那些设置项:
threshold: 0, // 指定间隔底部若干间隔时触发加载
event: 'scroll', // 指定触发事宜,默许为'scroll'
js_effect: undefined, // 显现图片的js动画结果
css_effect: undefined, // 显现图片的css动画结果
container: window, // 指定容器,默许为window
parent: undefined, // 能够指定动画结果作用于元素的哪一个父级元素
appear: null, // 元素出如今可视窗口时触发appear钩子函数
load: null, // 元素图片的加载完后触发load钩子函数
error: null, // 图片加载失足时触发error钩子函数
node_type: 'img', // 指定天生的节点范例,默许为'img'
placeholder: // 占位元素,除了支撑一般的图片外,还支撑react组件。
'data:image/png;base64,iVBORw0KGgo#ANSUhEUg#AE#ABCAY#AfFcSJ#AAXNSR0IArs4c6Q#ARnQU1BAACxjwv8YQU#AJcEhZcwAADsQ#7EAZUrDhs#ANSURBVBhXYzh8+PB/AAffA0nNPuCL#AAElFTkSuQmCC',
是否是很眼熟 ?,假如你熟习 jquery.lazyload,那末你只需相识以下几个设置项即可:
2. 支撑 velocity.js、animate.css 动画结果库,及自定动画结果。同时还支撑动画结果作用于父级元素。
- 指定 js-effect 设置项来设置 velocity.js 动画结果
注重:js-effect 依赖于 velocity.js。须要确保 velocity.js 已加载。
// 引入 lazyimg
import Lazyimg, { withLazyimg } from 'react-lazyimg-component';
// 引入 volecity.js
import 'velocity-animate';
import 'velocity-animate/velocity.ui';
// 设置
const cOnfig= {
placeholder: 'loading.svg',
js_effect: 'transition.fadeIn', // 支撑 velocity.js 动画结果
};
const Lazy = withLazyimg(config);
// 挪用
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
直接上结果了 ?
- 指定 css-effect 设置项来设置 animate.css 动画结果
注重:css-effect 依赖于 animate.css。须要确保 animate.css 已装置。
// 设置
const cOnfig= {
js_effect="transition.flipXIn" // 不会见效
css_effect={['animated', 'rollIn']} // 定制 css 动画结果
};
const Lazy = withLazyimg(config);
// 挪用
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
直接上结果了 ?
singsong: 为何懒加载的动画结果只作用于目的元素,某些条件下作用于目的元素的父级元素会有意想不到结果哦 ?。
// 指定动画结果作用于该父级元素
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
css_effect={['animated', 'flipInY']} // 定制 css 动画结果
parent=".example" // 指定父级元素选择器,也能够指定父级层级level:2
/>
直接上结果了 ?
3. react 组件式 placeholder
singsong: 传统的 placeholder 一般都是由图片来替代,为何不能用组件来定制,如许可扩展性更高。完整能够挣脱设计师的约束,咋们开辟自由发挥?! 想一想有木有有点小鸡冻 ? ~~
import React from 'react';
import './style.scss';
export default props => {
let { className, text, img, children } = props;
return (
className={['placeholder', className]
.filter(item => {
if (item) {
return item;
}
})
.join(' ')}
>
{img &&
}
{text &&
{children || text}}
);
};
- 指定 placeholder 设置项为上述定义的 placeholder 组件
// 设置
const Lazy = withLazyimg({
js_effect: 'transition.perspectiveDownIn',
placeholder: ,
});
// 挪用
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
直接上结果了 ?
singsong: 图中小火焰有木有很刺眼 ~
接着咋们来看看组件式 placeholder 运用场景案例,直接上结果了 ?
上图是分类页经由过程定制显现案牍的 placeholder 组件来替代一般的灰色图片,结果是否是看着还行 ?。这是我在现实项目中运用的案例。这里小伙伴能够自由发挥哈~。假如你有不错 idea 能够@我哈,先谢了!
4. 相应式图片( picture / srcset )
为了完成 web 运用的极致体验,Progressive Web App 渐进式网页运用程序愈来愈遭到开辟者们注重,个中相应式图片就是个中一个主要手艺项。为了随着大军队,咋们也须要相识相识噢!
// dpr
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
srcSet="source_1x.png 1x, source_2x.png 2x, source_3x.png 3x, source_3.5x.png 3.5x"
js_effect="transition.bounceIn"
/>
直接上结果了 ?
singsong: 这里 srcset 合营 sizes 特征能够完成更好的结果
直接上结果了 ?
后语
这个插件是我由项目中提炼出的,个人用着还挺随手,就拿出与人人分享分享。别的,毕竟个人能力有限,假如你发明插件有题目或有什么好的发起,也请示知一下,先这里谢过了 ?。末了迎接star?、迎接watch?、迎接fork?