副标题: 为何我要写这个 react 插件css
图片懒加载是项目中经常使用的功能,然而现有 react 懒加载组件库,用着都不是很爽了 😝。归纳一下有以下几点:html
清楚本身想要什么样的组件,就本身动手撸呗 😎。因而乎,react-lazyimg-component 就诞生了 😆。我们先来看看它的效果吧:node
singsong: 若是你们有时间,窝仍是鼓励你们本身动手实现一些小插件。react
使劲猛击这里jquery
在那个 jQuery 一统天下的年代,撸代码就用 jQuery 一把梭。其中 jQuery.lazyload 是一个很经常使用图片懒加载插件。 可能不少像我同样的小伙伴们,懒加载就直接上 jQuery.lazyload,早已习惯了 jQuery.lazyload 使用。 因而本身就琢磨可否继承 jQuery.lazyload 使用方法同时保持 react 特有组件特性。这样能够很快上手~~~~~😝git
singsong: 这里只是继承了 jQuery.lazyload 配置特性,不是彻底继承。毕竟 jQuery 与如今主流的 MVVM 框架思想大相径庭。github
若是小伙伴们熟悉 jQuery.lazyload , 彻底没有学习成本直接上手 react-lazyimg-component 哈。 只说不是写,然并卵。那咱们来看看它到底好用不:web
// npm
$> npm install react-lazyimg-component
// yarn
$> yarn add react-lazyimg-component
复制代码
// 引入
import Lazyimg, { withLazyimg } from 'react-lazyimg-component';
// 调用
<Lazyimg
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
复制代码
是否是很简单,有木有 😝。上述只是使用 react-lazyimg-component 的默认配置。 这里咱们能够经过配置项来定制懒加载的行为:npm
// 引入 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);
// 调用
<Lazy
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
复制代码
接下来咱们来看看 react-lazyimg-component 都那些配置项:api
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,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC',
复制代码
是否是很眼熟 😄,若是你熟悉 jquery.lazyload,那么你只需了解以下几个配置项便可:
js_effect: 指定元素显示的动画效果,基于velocity.js
动画实现。使用以前需加载velocity.js
。
css_effect: 指定元素显示的动画效果,基于animate.css
动画实现。使用以前需安装animate.css
。
parent: 用于指定动画效果做用于元素的哪一个父级元素。可取值:
node_type: 指定 react 将生成的元素类型,默认为'img'。
placeholder: 占位元素,除了支持普通的图片外,还支持 react 组件。
注意: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);
// 调用
<Lazy
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
复制代码
直接上效果了 😝
注意:css-effect 依赖于 animate.css。须要确保 animate.css 已安装。
// 配置
const config = {
js_effect="transition.flipXIn" // 不会生效
css_effect={['animated', 'rollIn']} // 定制 css 动画效果
};
const Lazy = withLazyimg(config);
// 调用
<Lazy
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
复制代码
直接上效果了 😝
singsong: 为何懒加载的动画效果只做用于目标元素,某些条件下做用于目标元素的父级元素会有意想不到效果哦 😝。
<div className="example">
// 指定动画效果做用于该父级元素
<Title title="父级动画效果" className="sub" />
<div className="example-img"> <Lazyimg className="lazy" src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'} css_effect={['animated', 'flipInY']} // 定制 css 动画效果 parent=".example" // 指定父级元素选择器,也能够指定父级层级level:2 /> </div> </div>
复制代码
直接上效果了 😝
singsong: 传统的 placeholder 一般都是由图片来代替,为何不能用组件来定制,这样可扩展性更高。彻底能够摆脱设计师的束缚,咋们开发自由发挥😯! 想一想有木有有点小鸡冻 😝~~~~~~
import React from 'react';
import './style.scss';
export default props => {
let { className, text, img, children } = props;
return (
<div className={['placeholder', className] .filter(item => { if (item) { return item; } }) .join(' ')} > {img && <img src={img} className="placeholder-img" />} {text && <span className="placeholder-text">{children || text}</span>} </div> ); }; 复制代码
// 配置
const Lazy = withLazyimg({
js_effect: 'transition.perspectiveDownIn',
placeholder: <Placeholder img={require('./loading.svg')} />,
});
// 调用
<Lazy
className="lazy"
src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'}
/>;
复制代码
直接上效果了 😝
singsong: 图中小火焰有木有很耀眼~~~~~
接着咋们来看看组件式 placeholder 应用场景案例,直接上效果了 😝
上图是分类页经过定制显示文案的 placeholder 组件来代替普通的灰色图片,效果是否是看着还行 😝。这是我在实际项目中使用的案例。这里小伙伴能够自由发挥哈~~~~~。若是你有不错 idea 能够@我哈,先谢了!
为了实现 web 应用的极致体验,Progressive Web App 渐进式网页应用程序愈来愈受到开发者们重视,其中响应式图片就是其中一个重要技术项。为了跟着大部队,咋们也须要了解了解噢!
// dpr
<Lazyimg 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 特性能够实现更好的效果
<picture>
<source media="(min-width: 650px)" srcSet="https://www.w3schools.com/tags/img_pink_flowers.jpg" />
<source media="(min-width: 465px)" srcSet="https://www.w3schools.com/tags/img_white_flower.jpg"/>
<Lazyimg className="lazy" src={'http://zhansingsong.github.io/lazyimg/22.4582fc71.jpg'} js_effect="transition.expandIn" />
</picture>
复制代码
直接上效果了 😝
这个插件是我由项目中提炼出的,我的用着还挺顺手,就拿出与你们分享分享。另外,毕竟我的能力有限,若是你发现插件有问题或有什么好的建议,也请告知一下,先这里谢过了 😝。最后欢迎star😝、欢迎watch😝、欢迎fork😝