csdn推荐
文章目录
前言
高阶组件有几大优点,其中一个就是渲染劫持,如懒加载,是否显示该元素loading,这在项目中我们经常用到。毫无疑问,这个实战系列我们必然也要用到它,本文主要封装这个loading组件,为了后期开发页面使用。
Loading组件 1. 功能分析
(1)通过size属性,可以自定义加载动画的尺寸
(2)通过传入className属性, 可以自定义加载动画的样式
(3)通过传入imgUrl属性, 可以自定义加载动画的图片
(4)组件使用了 classNames 库来合并样式类名,并且使用了 css模块,和styles 模块中的样式类名来设置Loading的样式
2. 代码+详细注释
// @/components/Loading/index.tsx
import { FC } from "react";
import classNames from "classnames";
import { LoadingBlock } from "./styled";
import LoadingImage from "@/assets/logo.png";
// 组件的属性类型
type Props = {
// loading的尺寸
size?: "small" | "large";
// 自定义的类名
className?: string;
// 自定义的图片地址
imgUrl?: string;
};
// 动画懒加载组件
const Loading: FC<Props> = ({ size, className, imgUrl }) => (
<LoadingBlock className={classNames(className)} size={size}>
<img src={imgUrl ?? LoadingImage} alt="loading" />
</LoadingBlock>
);
export default Loading;
------------------------------------------------------------------------------
// @/components/Dialog/styled.tsx
import styled, { css } from "styled-components";
import variables from "@/styles/variables.module.scss";
const sizeStyles = {
small: css`
width: 100px;
`,
large: css`
width: 300px;
`,
};
export const LoadingBlock = styled.div<{ size?: "small" | "large" }>`
margin: 18px 0;
text-align: center;
img {
width: 200px;
${({ size }) => size && sizeStyles[size]}
}
@media (max-width: ${variables.mobileBreakPoint}) {
margin: 8px 0;
img {
width: 60px;
}
}
`;
3. 使用方式
// 引入组件
import Loading from "@/components/Loading";
// 使用
<Loading size="small" /> {/* 小尺寸loading */}
<Loading /> {/* 默认尺寸loading */}
<Loading size="large" /> {/* 大尺寸loading */}
4. 不同尺寸loading动画效果展示
总结
文章来源:https://blog.csdn.net/weixin_43883615/article/details/139801842
微信扫描下方的二维码阅读本文
© 版权声明
THE END
暂无评论内容