yearrecord——一个类似痕迹墙的React数据展示组件

介绍一下自己做的一个类似于力扣个人主页提交记录和GitHub主页贡献记录的React组件。

下图分别是力扣个人主页提交记录和GitHub个人主页的贡献记录,像这样类似痕迹墙的形式可以比较直观且高效得展示一段时间内得数据记录。

然而要从0实现这个功能还是有一些麻烦得,并且该功能可用的场景也比较多,于是便把它做成了一个通用的组件,只需要提供数据即可渲染这样的效果。

如何使用

安装

在一个React项目中:

shell 复制代码
npm install yearrecord

使用

引入后当成普通的组件通过data这个prop传递数据即可,也可以不传递任何的prop,这样将使用随机生成的数据,颜色、尺寸等将使用使用默认值。

js 复制代码
import YearRecord from "yearrecord"

function App() {

  return (
    <>
      <YearRecord
        themeColor="green"
        tooltipTitileFunc={item => `${item.year}年${item.month}月${item.day}日, ${item.data}次浏览`}
      ></YearRecord>
    </>
  )
}

export default App

然后可得到如下的渲染结果:

组件提供了较高的可配置能力,可通过props自定义主题颜色、间距、尺寸、tooltip title等等,具体可参考项目主页的API表格。

目前该组件仅完成了比较核心的功能,相对于GitHub的贡献记录还有一些特性没有实现,如果有感兴趣的小伙伴,欢迎来给这个组件提issue、提pr,如果能给一个star就更好了🤣

项目主页:https://qgq99.github.io/yearrecord/

代码地址:https://github.com/qgq99/yearrecord

感谢支持!

相关推荐
混血哲谈2 天前
lodash-es中的set和get的用法
react·lodash-es
东离与糖宝4 天前
`console.log` 打印一个对象并且得到 `“object Object“`
前端·笔记·react.js·js
唯之为之4 天前
JS脚本批量处理TS数据类型
typescript·js
寒江孤影d4 天前
Vue3-win7搭建vue3环境
vue·vue3·js·win7
儿鱼4 天前
微信小程序vue3父组件调用vue2子组件传多个参数方法
vue.js·微信小程序·vue·js
终末圆5 天前
【前端 23】用Less优化你的CSS书写体验
c语言·前端·javascript·css·网络·less·js
丁先生3205 天前
基于element-ui 日期选择器el-date-picker, 即对日期做区间限制
前端·javascript·elementui·vue·react
ZhaiMou7 天前
实现 前端框架 SPA 路由功能:Hash 模式与 History 模式的手动实现
前端·vue.js·算法·前端框架·reactjs·哈希算法·react
Evisu47(常安欧阳)8 天前
Tree组件的快速定位更新节点的状态,以及修改节点的数据属性等操作
javascript·react
心态还需努力呀10 天前
HTML+CSS+JS实现商城首页[web课设代码+模块说明+效果图]
前端·css·html·js·web大作业