查看: 85|回复: 0

React Color使用

[复制链接]

2

主题

0

回帖

0

积分

热心网友

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2011-10-24
发表于 2021-9-7 08:56:00 | 显示全部楼层 |阅读模式

需求

- 要在react项目中实现颜色获取器功能

解决方案

- 使用react-color 依赖

- git地址:https://github.com/casesandberg/react-color

- 文档地址:http://casesandberg.github.io/react-color/#api-onChange

使用

1. 安装react color 依赖

yarn add react-color @types/react-color
  • 项目中没有使用typescript时,不需要@types/react-color

2. 按需引入

import React from 'react';
import { SketchPicker } from 'react-color';

function ColorPicker  {
  const [color, setColor] = useState("#333");

  render() {
    return <SketchPicker 
                color={color}
                onChangeComplete={ (color:any)=>setColor(color.hex) }
           />;
  }
}
  • 除了SketchPicker,还有Chrome Photoshop Block Github Twitter Hue Alpha Circle Slider Compact Material Swatches几种,可以根据需要引入相应组件。

API

1. color

  • 颜色选择器颜色选中值,即可接收hex'#333',也可以接受rgb{ r: 51, g: 51, b: 51, a: 1 },也可以接受hsl{ h: 0, s: 0, l: .10, a: 1 }

2. onChange

  • 每次颜色改变都会触发该方法,返回color对象color:{hex: '#333', rgb: {r: 51, g: 51, b: 51, a: 1 },hsl:{ h: 0, s: 0, l: .10, a: 1 }

3. onChangeComplete

  • 颜色选择完成后触发该方法,与onChange类似,我理解是onChange的优化,onChange触发相对频繁,如果仅是获取选中的颜色,使用onChangeComplete即可。


来源:https://www.cnblogs.com/shellon/p/15236685.html
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部