小哥哥小姐姐看过来,这里有个组件库需要您签收一下

404NotFound
• 阅读 3507

1. 前言

一直以来都想做个组件库,一方面是对工作中常遇问题的总结,另一方面也确实能够提升工作效率(谁又不想造一个属于自己的轮子呢~),于是乎就有了本文的主角儿rn-components-kit

市面上web的UI组件库如此之多,react相关的有antdvue相关的有element。不过,今天介绍的是react-native的一个组件库。不同于上述组件库都有统一的视觉规范,rn-components-kit更注重的是在提供组件基本能力的同时尽可能多地赋予自定义样式的可能性。

放上仓库地址,欢迎star,欢迎提issue,欢迎提PR~

下面就让我们来认识一下rn-components-kit~

2. 快速开始

2.1 安装

你可以通过下面的命令安装rn-components-kit:

npm install rn-components-kit --save
import React from 'react';
import {Badge} from ' @rn-components-kit/badge';

const TestComponent = () => <Badge/>;

2.2 按需加载

上述的方法将会把所有的组件打进bundle内,即使你没有用到所有的组件。如果你想减少包大小,你可以这样引入:

npm install @rn-components-kit/badge --save
import React from 'react';
import {Badge} from ' @rn-components-kit/badge';

const TestComponent = () => <Badge/>;

事实上,每个组件都是支持单独安装的,我们也推荐你使用这种方式引入组件。

2.3 运行示例

我们创建了一个app专门用来演示每个组件的使用方法以及运行效果,如果你想运行这个例子,你需要先下载本仓库到本地。

# download repo
git clone https://github.com/SmallStoneSK/rn-components-kit.git

# install dependencies
npm install

# for iOS
react-native run-ios

# for android
react-native run-android

以下是运行示例app后各界面的截图:

小哥哥小姐姐看过来,这里有个组件库需要您签收一下

3. 组件

3.1 Badge

图标右上角的圆形徽标数字。支持以下特性:

  • 纯圆点和带文字圆点两种样式
  • 自定义颜色
  • 友好的过渡动画
npm install @rn-components-kit/badge --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4

3.2 Button

按钮组件,支持以下特性:

  • defaultprimarysuccesswarningdanger5种主题
  • smalldefaultlarge3种大小
  • squaredefaultround3种形状
  • 支持icon按钮和控制图标位置
  • 支持outline样式按钮
  • 支持block样式按钮
  • 支持link样式按钮
npm install @rn-components-kit/button --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo5
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo6
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo7

3.3 Carousel

轮播组件,就像"旋转木马"一样。支持以下特性:

  • 水平/垂直两个方向
  • 循环模式
  • 自动播放模式
  • 居中模式,当前项会被调整至一屏的中间,同时前一项/后一项也会露出一部分
  • 支持轮播内容不足一屏的长度

注意

  1. 当使用水平模式时,widthitemWidth必须设置。
  2. 当使用垂直模式时,heightitemHeight必须设置。
  3. 如果轮播组件内容的数据源(数组)是会变化的,需要设置数据源作为data属性,不然轮播组件中的内容将不会更新。
  4. 下面的图片将有助于理解一些样式上的重要变量含义:

小哥哥小姐姐看过来,这里有个组件库需要您签收一下

npm install @rn-components-kit/carousel --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo5
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo6
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo7

3.4 CheckBox

复选框组件。

npm install @rn-components-kit/checkbox --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4

3.5 DeckSwiper

DeckSwiper让你一次评估一个选项,而不是从一组选项中进行选择。

npm install @rn-components-kit/deck-swiper --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1

3.6 Divider

分割线组件,支持两种方向: horizontalvertical.

npm install @rn-components-kit/divider --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2

3.7 Icon

语义化的矢量图形。支持以下特性:

注意:确保你的项目已经集成了ART模块

如果你遇到诸如No component found for view with name "ARTXXX"之类的报错,那是因为你的项目还没有集成ART模块。你需要:

  1. 使用Xcode打开项目下的ios工程,Libraries -> Add Files to -> node_modules/react-native/Libraries/ART/ART.xcodeproj
  2. 点击项目根目录,找到Linked Frameworks and Libraries,点击+选择libART.a,然后重新编译工程。
  3. 重新编译完成后,重新运行命令react-native run-ios/android,重启项目。
npm install @rn-components-kit/icon --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3

3.8 Progress

进度条组件,展示当前操作进度,支持以下特性:

  • linecircle两种类型
  • normalactivesuccessfail四种状态
  • 自定义颜色,支持线性渐变(目前仅限line类型)
  • 自定义进度文案格式,甚至支持信息展示区域完全自定义

注意

由于本组件支持线性渐变选项,所以你的项目需要集成react-native-linear-gradient。如果你的项目还没集成,你可以参照这里的指示完成。

npm install @rn-components-kit/progress --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo5

3.9 Radio

Radio组件让用户从一堆选项中选择一项,支持以下特性:

  • 禁用点击
  • 自定义选中/未选中icon或图片
  • 状态切换时有过渡动画
npm install @rn-components-kit/radio --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4

3.10 Rating

评分组件,支持以下特性:

  • 支持点选滑动操作进行评分
  • 自定义图标样式(包括类型颜色大小
  • 支持不同的滑动步长(例如:0.1/0.2/0.5/1)
npm install @rn-components-kit/rating --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3

3.11 ScrollPicker

滚动选择器,支持以下特性:

  • 抹平AndroidiOS平台的交互差异
  • 支持多项选择器
  • 支持级联选择
  • ScrollPicker.Item支持自定义选项内容
npm install @rn-components-kit/scroll-picker --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3

3.12 Skeleton

骨架屏,常在loading时起占位的作用,支持以下特性:

  • avatartitleparagraph 三部分均支持定制化
  • 可以使用高阶组件withSkeleton完全定制化骨架屏的组成和样式

注意

当你使用装饰器的语法使用高阶组件withSkeleton时,确保你的项目安装了插件@babel/plugin-proposal-decorators.

npm install @rn-components-kit/skeleton --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2

3.13 Slider

以滑动的交互形式,从指定范围内选择值。支持以下特性:

  • 水平垂直两种方向
  • 12个滑块
  • 滑块和轨道样式高度可定制化
  • tip文案可定制化
npm install @rn-components-kit/slider --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4

3.14 Spin

用于展示页面或区块的加载中状态。支持以下7种不同动画类型:

  • Ladder
  • Rainbow
  • Wave
  • RollingCubes
  • ChasingCircles
  • Pulse
  • FlippingCard
npm install @rn-components-kit/spin --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo5
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo6
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo7

3.15 SwipeOut

iOS样式的滑动隐藏按钮组件,支持以下特性:

  • 支持两个方向滑出
  • 隐藏部分支持多个按钮配置
  • 隐藏部分完全自定义
npm install @rn-components-kit/swipe-out --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3

3.16 Switch

开关选择器,支持以下特性:

  • 自定义颜色
  • 自定义大小
  • 两种风格: cupertinomaterial
npm install @rn-components-kit/switch --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo4
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo5

3.17 Tag

进行标记和分类的小标签。支持以下特性:

  • 自定义颜色
  • 支持两种风格:outlinesolid
  • 可关闭及其关闭事件回调函数
npm install @rn-components-kit/tag --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo2
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo3

3.18 Tooltip

当用户点击某个元素,展示一个气泡框,支持以下特性:

  • 气泡框支持topbottom两个方向
  • 完全自定义气泡框内容
npm install @rn-components-kit/tooltip --save

详细API请查看文档

组件示例预览效果 代码
小哥哥小姐姐看过来,这里有个组件库需要您签收一下 Demo1

4. 写在最后

最后再次放上仓库地址,欢迎star,欢迎提issue,欢迎提PR~

你也可以关注我的Blog,欢迎一起交流学习~

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Wesley13 Wesley13
4年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
4年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Wesley13 Wesley13
4年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
4年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Easter79 Easter79
4年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
4年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Python进阶者 Python进阶者
2年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这