react基于antd二次封装spin组件

react基于antd二次封装spin组件

组件

import {
    Spin } from 'antd';
import propTypes from "prop-types";
import React from 'react';
import styleId from "styled-components";
// 使用 父div必须加 position:'relative'
const SpinCom = (props) => {
   
  // console.log('props',props);
    return (
        <SpinComWrap>
          <Spin className='spin' tip={
   props.tip} spinning={
   props.spinning} />
        </SpinComWrap>
    )
}
// props
SpinCom.propTypes = {
   
  tip: propTypes.string,
  spinning: propTypes.bool.isRequired,
  size: propTypes.string,
};
SpinCom.defaultProps = {
   
  tip: 'Loading...', // 默认值
  spinning: false,
  size: 'default'
};
const SpinComWrap = styleId.div`
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  .spin {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
  }
`
export default SpinCom

使用组件

import {
    Button } from 'antd';
import React, {
    useState } from 'react';
import SpinCom from "./SpinCom";
export default function App(props) {
   
  const [show,setshow] = useState(false)
  const showspain = () => {
   
    setshow(!show)
  }
    return (
        <div className='content' style={
   {
   width:'200px',height: '200px',background: '#ccc',position:'relative'}}>
          <SpinCom spinning={
   show}></SpinCom>
          app -{
   show ? 1: 0}
          <Button type="primary" onClick={
   showspain}>Button</Button>
        </div>
    )
}

效果

在这里插入图片描述

相关推荐

  1. react基于antd封装分页组件Pagination

    2023-12-19 05:48:02       63 阅读
  2. [React]利用Webcomponent封装React

    2023-12-19 05:48:02       17 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-19 05:48:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-19 05:48:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-19 05:48:02       82 阅读
  4. Python语言-面向对象

    2023-12-19 05:48:02       91 阅读

热门阅读

  1. 速盾网络:业务卓越,数字安全的领先者

    2023-12-19 05:48:02       63 阅读
  2. 创建型模式 | 单例模式

    2023-12-19 05:48:02       58 阅读
  3. Qt之图像处理

    2023-12-19 05:48:02       58 阅读
  4. GO语言实现视频分割

    2023-12-19 05:48:02       58 阅读
  5. 前端不同架构的分层设计

    2023-12-19 05:48:02       61 阅读
  6. 开发语言:ArkTS

    2023-12-19 05:48:02       68 阅读
  7. node.js 全部进程挂了,如何使用pm2恢复?

    2023-12-19 05:48:02       58 阅读
  8. Node.js中npm中ws的WebSocket协议的实现

    2023-12-19 05:48:02       57 阅读