antd Slider 根据数据展示

这篇博客展示了如何在React应用中利用Ant Design的Slider组件,并通过自定义marks属性来显示个性化标记,每个标记包含人物名称和对应的高度或金钱值。CSS部分定义了不同标记的背景渐变颜色,区分奇偶性,并调整了滑块的样式,如点、步和文字间距。
摘要由CSDN通过智能技术生成

在这里插入图片描述

index

import React from 'react'
import styles from './style.less'
import { Slider } from 'antd';
const data = [
    {
        height: 148.9,
        name: '羽神',
        money: 250,
    },
    {
        height: 159,
        name: '少主',
        money: 189,
    },
    {
        height: 188,
        name: '大鼎',
        money: 13220,
    },
    {
        height: 188,
        name: '赵老威',
        money: 13220,
    },
    {
        height: 188,
        name: '郭帅',
        money: 13220,
    },
    {
        height: 188,
        name: '那个街口 我丢失了你',
        money: 13220,
    },
    {
        height: 188,
        name: '铜锣湾扛把子',
        money: 13220,
    },

]
const marks = {};
for (const key in data)
{
    console.log(data.length, 'length');
    let index = (100 / (data.length - 1)) * Number(key)  // -1 因为 antd 默认有个终点
    marks[index] = <strong className={key % 2 === 0 ? styles.marksEven : styles.marksOdd} >{data[key].name}</strong>  // 根据奇数偶数 给不同颜色
}
const index = () =>
{
    return (
        <div className={styles.container}>
            <Slider marks={marks} defaultValue={100} disabled className={styles.sli} />
        </div>
    )
}

export default index

CSS

body {
  background: linear-gradient(#243949, #517fa4);
  display: flex;
  justify-content: center;
  align-items: center;

  .container {
    width: 1000px;

    .marksEven {
      // 偶数
      background: linear-gradient(to right, rgba(182, 54, 128) 0%, rgba(16, 202, 100, ) 100%);

    }

    .marksOdd {
      // 奇数
      background: linear-gradient(to right, rgb(231, 120, 157, .3) 0%, rgb(254, 225, 64, .1) 100%);
    }

    .marksEven,
    .marksOdd {
      cursor: pointer;
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
    }

  }

}


:global {
  .ant-slider-dot {
    // 点
    position: absolute;
    top: -4px;
    width: 12px;
    height: 12px;
    border: 2px solid #f0f0f0;
    cursor: pointer;
  }

  .ant-slider-step {
    // 步
    position: absolute;
    width: 100%;
    height: 4px;
    background: rgb(25, 184, 144);
  }

  .ant-slider-disabled .ant-slider-handle,
  .ant-slider-disabled .ant-slider-dot {
    background-color: #17b324;
    box-shadow: none;
    cursor: not-allowed;
  }

  .ant-slider-mark {
    // 文字距离
    position: absolute;
    top: 18px;
    left: 10px;
    width: 100%;
    font-size: 16px;
    font-weight: 500;
  }

  //   .ant-slider-mark-text {
  //     // 文字颜色
  //     cursor: pointer;
  //     background: linear-gradient(to right, rgb(231, 120, 157, .3) 0%, rgb(254, 225, 64, .1) 100%);
  //     -webkit-background-clip: text;
  //     -webkit-text-fill-color: transparent;
  //   }
}

Ant Design(简称AntD)是一个基于React的UI库,提供了丰富的组件和高度一致的设计风格,非常适合用于数据展示AntD中的数据展示功能强大且易于使用,主要体现在以下几个方面: 1. 表格(Table):它是AntD中最常用的数据展示组件,支持大规模数据的分页、排序、搜索以及自定义列等,非常适合处理结构化数据。 2. 图表.Chart:AntV是Ant Group的开源数据可视化库,提供了多样化的图表类型,如折线图、柱状图、饼图、仪表盘等,可以直观地呈现数据趋势和对比。 3. 数据列表(List):适合展示有序或无序的项目列表,支持动态加载、分组、筛选等功能。 4. Grid:网格布局组件,适合展示复杂的数据布局,例如数据表格与图表混合展示的场景。 5. Form:数据表单组件,配合Form.Item可以方便地组织和验证数据输入,常用于数据录入界面。 6. Tree/TreeSelect:树形结构展示数据,比如文件夹结构或组织架构。 7. Pagination:灵活的分页控件,方便处理大量数据的分页展示。 为了让你更好地使用AntD进行数据展示,你可以: - 根据具体需求选择合适的组件,比如`<Table>`、`<Chart>`或`<Form>`。 - 利用API和配置项定制样式和行为,如调整列宽、设置主题颜色等。 - 了解并使用其提供的响应式设计,适应不同设备的显示效果。 - 参考官方文档和示例代码,学习如何集成和优化组件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

臧小川

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值