一、卡片Card分类

  • 与普通卡片使用区别:底部按钮及内容样式

    <Card
    hoverable
    bodyStyle={{ paddingBottom: 20 }}
    actions={[ // 卡片操作组,位置在卡片底部
    <Button size='large' onClick={() => this.showEditModal(item)}>修改</Button>,
    <Popconfirm title="是否要删除此孵化企业?" onConfirm={() => this.deleteItem(item)}>
    <Button type='danger' size='large'>删除</Button>
    </Popconfirm>
    ]}
    >
    <Card.Meta avatar={<Avatar size="small" src={`${setFileHost() + item.comLogo}`} />} title={item.comName} /> //头像、类名、描述等,位置在卡片左侧
    <div className={styles.cardItemContent}>
    <CardInfo
    productCount={item.productCount}
    />
    </div>
    </Card>

  • 动态添加卡片分类:List的dataSource数组第一个位置为空串,遍历时,遇到item渲染卡片,否则ListItem中包裹自定义按钮

    <List
    rowKey="id"
    loading={loading}
    grid={{ gutter: 24, lg: 3, md: 2, sm: 1, xs: 1 }}
    dataSource={['', ...list]} // 构建第一个位置为空串的list数组
    renderItem={item =>
    item ? (
    <List.Item key={item.id}>
    <Card hoverable className={styles.card}
    actions={[ <a onClick={() => this.editCategory(item)}>修改</a>,
    <Popconfirm title="是否要删除此分类?" onConfirm={() => this.deleteCategory(item)}>
    <a style={{color: 'red'}}>删除</a>
    </Popconfirm>
    ]}>
    <Card.Meta
    avatar={<img alt="" className={styles.cardAvatar} src={`${setFileHost() + item.categoryLogo }`} />}
    title={<a style={{ fontWeight: 600 }}>{item.categoryName}</a>}
    description={
    <Ellipsis className={styles.item} lines={3}>
    {`共 ${item.productCount}个商品`}
    </Ellipsis>
    }
    />
    </Card>
    </List.Item>
    ) : (
    <List.Item> // 空串位置 渲染按钮
    <Button type="dashed" className={styles.newButton} onClick={() => this.addCategory()}>
    <Icon type="plus" /> 新增分类
    </Button>
    </List.Item>
    )
    />

  

二、分布表单

  • <Step/>步骤条组件的使用,current指定当前步骤,从 0 开始记数

    export default class StepForm extends PureComponent {
    getCurrentStep() {
    const { location } = this.props;
    const { pathname } = location;
    const pathList = pathname.split('/');
    switch (pathList[pathList.length - 1]) {
    case 'info':
    return 0;
    case 'confirm':
    return 1;
    case 'result':
    return 2;
    default:
    return 0;
    }
    } render() {
    const { location, children } = this.props; return (
    <PageHeaderWrapper
    title="分步表单"
    tabActiveKey={location.pathname}
    content="将一个冗长或用户不熟悉的表单任务分成多个步骤,指导用户完成。"
    >
    <Card bordered={false}>
    <Fragment>
    <Steps current={this.getCurrentStep()} className={styles.steps}>
    <Step title="填写转账信息" />
    <Step title="确认转账信息" />
    <Step title="完成" />
    </Steps>
    {children} // 可直接写为三个状态对应的三个表单子组件
    </Fragment>
    </Card>
    </PageHeaderWrapper>
    );
    }
    }

    有个疑问:框架自带Mock页面Form->StepForm->index.js、step1.js、step2.js、step3.js实现切换表单的方式还没弄明白。。。 


注:转载请注明出处

【后台管理系统】—— Ant Design Pro 页面相关(三)的更多相关文章

  1. 【后台管理系统】—— Ant Design Pro页面相关(二)

    一.弹框Modal表单 使用Form.create()包装得到一个含有this.props.form属性的CreatForm自组件 从页面主(父)组件获得props数据和propsMethod方法 r ...

  2. 【后台管理系统】—— Ant Design Pro页面相关(一)

    一.List列表形式 import React, { PureComponent } from 'react'; import { findDOMNode } from 'react-dom'; im ...

  3. 【后台管理系统】—— Ant Design Pro入门学习&项目实践笔记(三)

    前言:前一篇记录了[后台管理系统]目前进展开发中遇到的一些应用点,这一篇会梳理一些自己学习Ant Design Pro源码的功能点.附:Ant Design Pro 在线预览地址. Dashboard ...

  4. Ant Design Pro (中后台系统)教程

    一.概念:https://pro.ant.design/docs/getting-started-cn(官方网站) 1.Ant Design Pro 是什么:  https://www.cnblogs ...

  5. Ant Design Pro项目打开页设为登录或者其他页面

    Ant Design Pro项目打开页设为登录或者其他页面 一.打开页设为登录页 首先找到utils包中的authority文件,在该文件中找到如下代码: export function getAut ...

  6. 测试平台系列(5) 引入Ant Design Pro

    引入Ant Design Pro 回顾 还是继续回顾下之前的作业, 返回的中文变成了ascii字符,不要紧,我们光荣地百度一哈. 随便点进去看看,都可以找到正确答案: 可以看到,我们需要修改confi ...

  7. 阿里开源项目之Ant Design Pro

    本篇文章主要包含的内容有三个方面. 第一.Ant Design Pro简介; 第二.Ant Design Pro能做什么; 第三.初步使用; 我相信通过这三个方面的讲解能让你大概知道Ant Desig ...

  8. ant design pro (十三)advanced 错误处理

    一.概述 原文地址:https://pro.ant.design/docs/error-cn 二.详细 2.1.页面级报错 2.1.1.应用场景 路由直接引导到报错页面,比如你输入的网址没有匹配到任何 ...

  9. ant design pro(一)安装、目录结构、项目加载启动【原始、以及idea开发】

    一.概述 1.1.脚手架概念 编程领域中的“脚手架(Scaffolding)”指的是能够快速搭建项目“骨架”的一类工具.例如大多数的React项目都有src,public,webpack配置文件等等, ...

随机推荐

  1. HashMap、HashTable、ConcurrentHashMap、TreeMap、LinkedHashMap、WeakHashMap区别

    1. HashMap   标准链地址法实现(下图).数组方式存储key/value,线程非安全,允许null作为key和value,key不可以重复,value允许重复,不保证元素迭代顺序是按照插入时 ...

  2. css 空心圆

    用css实现一个空心圆,并始终放置在浏览器窗口左下角        div{                position:fixed;                bottom:0;      ...

  3. IntelliJ IDEA 远程调试 Tomcat 的方法

    在调试代码的过程中,为了更好的定位及解决问题,有时候需要我们使用远程调试的方法.在本文中,就让我们一起来看看,如何利用 IntelliJ IDEA 进行远程 Tomcat 的调试. 首先,配置remo ...

  4. Struts2对于BigDecimal类型的转换问题

    Struts2对常用的数据类型如String.Integer.Double等都添加了转换器进行对应的转换操作. BigDecimal其实也算作是一种常用的数据类型,但Struts2没有对该类型设置转换 ...

  5. 使用layer弹窗和layui表单做新增功能

    注释:代码参考http://blog.51cto.com/825272560/1891158,在其修改之上而来,在此感谢! 1.需求:使用layer在弹窗内完成新增,成功后提示并刷新页面(父页面,li ...

  6. luffyapi项目 --短信认证的基本操作

    一.开通腾讯云短信 SDK 文档 :https://cloud.tencent.com/document/product/382/11672 1.官网注册实名账号:https://cloud.tenc ...

  7. Python3使运行暂停的方法

    在Python3中已经有很大一部分语句与Python2不互通了,运行暂停的方法也有所不同. 1.input(); 这种方法不用包含模块,因此这也是最常用的一种暂停手段. Python2中的raw_in ...

  8. 使用Python的pandas-datareader包下载雅虎财经股价数据

    0 准备工作 首先,使用pip方法安装pandas和pandas-datareader两个功能包. 安装的方法十分简单,以管理员身份运行cmd. 输入以下命令. $ pip install panda ...

  9. java基本类型和包装类型的区别

    Java的类型分为两部分,一个是基本类型(primitive),如int.double等八种基本数据类型: 另一个是引用类型(reference type),如String.List等.而每一个基本类 ...

  10. 008-zabbix监控nginx

    (1)agent端配置 1)nginx编译安装需要加上该选项--with-http_stub_status_module 2)修改nginx配置文件 #vim /usr/local/nginx/con ...