npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

react-native-common-element

v0.10.0

Published

React-Native Elements

Downloads

30

Readme

react-native-common-element

暂时只适配ios端

安装

npm i -S react-native-common-element

Usage

  • 引入组件:
import { RNHeader } from 'react-native-common-element';

<RNHeader />;
  • 引入方法

import { screenUtil } from 'react-native-common-element';

Components

RNHeader - 页面头部

使用方法


<RNHeader
  backgroundColor="#3673ee" // 背景色
  leftComponent={{
    text: '返回',
    style: { color: '#fff' },
  }} // 左侧组件
  rightcomponent={<MyCustomComponent />}
  centerComponent={{}} // 中间组件
  leftContainerStyle={{}} // 左侧组件样式
  centerContainerStyle={{}} // 中间组件样式
  rightContainerStyle={{}} // 右侧组件样式
  containerStyle={} // container style
  barStyle={} // 状态栏样式
  statusBarProps={} // 状态栏props
/>

RNLoading - Loading

RNModal - Modal

使用方法


<RNModal
  animationIn="" // 入场动画类型,default:'slideInUp'
  animationOut="" // 消失动画类型,default:'slideOutDown'
  animationInTiming={} // 入场动画持续时间,default:300
  animationOutTiming={} // 消失动画持续时间,default:300
  isVisible={} // modal隐藏与显示状态,bool, required,
  backDropOpacity={} // modal遮罩透明度,default:0.7
  backDropColor="" // modal遮罩颜色,default:'#000'
  hasBackDrop={} // 是否需要遮罩,default:true
  onBackDropPress={() => {}} // 点击遮罩回调函数
  onModalWillHide={} // modal消失之前回调
  onModalHide={} // modal消失后回调
  onModalShow={} // modal显示后回调
  onModalWillShow={} // modal显示之前回调
  contentStyle={} // 内容style
  useNativeDriver={} // 使用原生动画驱动,default: false
>
  {/* children: modal内容,reuqired */}
  {children}
</RNModal>

RNDropDown - 下拉框

使用方法


<RNDropDown
  data={['我爱中国', '祖国万岁', '身体健康']} // 数据源,Required
  pickVal="祖国万岁" // 默认选中值
  containerStyle = {{}} // container样式
  renderBase = {() => {}} // 自定义头部
  pickerStyle={{
    width: '100%',
    backgroundColor: '#f1f1f1',
    height: 32,
    borderWidth: 1,
    borderColor: '#979797',
    borderRadius: 3,
  }} // 头部container样式
  pickTextStyle = {{}} // 头部文字样式
  overlayStyle = {{}} // 下拉框container样式
  itemContainerStyle = {{}} // option container样式
  itemTextstyle = {{}} // option文本样式
  itemActiveContainerStyle= {{}} // option 高亮container样式
  itemActiveTextstyle= {{}} // option高亮文字样式
  // 下拉选项option选择回调
  handleChange = {(item, index) => { console.log(item, index); }}
/>

RNEchart - 图表组件

使用方法


<RNEchart
  option={option} // option
  width={375} // 宽度值
  height={500} // 高度值
/>

RNCollapse - 折叠面板

使用方法


<RNCollapse
  isCollapse // 面板初始状态
  iconText="我是组件" // 头部文字
  collapseContainerStyle={styles.collapse} // 头部container style
  iconStyle={styles.icon} // 头部icon style
  iconTextStyle={styles.text} // 头部文字style
  handlePress={() => {}} // 头部点击回调
>
  <View style={{ width: '100%' }}>
    <Text>折叠面板</Text>
  </View>
</RNCollapse>

RNPlaceHolder - 占位图

使用方法


<RNPlaceholder
  animation="fade" // 暂不支持定制化
  isReady={false}
  whenReadyRender={() => <Text>加载完成</Text>}
>
  <View style={{ flexDirection: 'row', flex: 1, alignItems: 'center' }}>
    <Media
      color="pink" // 背景色
      width={90} // 宽度 number
      height={90} // 高度 number
      style={{}} // 样式
      borderRadius={45} // 圆角 number
      noMargin // 是否有marginBottom
    />
    <View style={{ flex: 1, marginLeft: 12 }}>
      <Line
        noMargin // 是否有marginBottom
        color="red" // 背景色
        width="50%" // 宽度 number or string
        textSize={12} // 基准大小
        style={{}} // 样式
      />
      <Line color="red" />
      <Line color="red" />
    </View>
  </View>
</RNPlaceholder>

RNPicker - 选择器

使用方法


<RNPicker
  isVisible={this.state.isVisible} // 可见状态
  toggleModal={(status) => { this.setState({ isVisible: status })}} // 切换可见状态函数
  pickerData={['2017年', '2018年', '2019年', '2020年', '2021年']} // 数据源
  selectedValue={this.state.selectedVal} // 选中项
  selectConfirm={(selectedVal) => {
    this.setState({
      selectedVal,
    })
  }} // 点击头部确认函数
  cancelBtnText="取消" // 取消按钮文字,默认“取消”
  confirmBtnText="确认" // 确认按钮文字,默认“确认”
  cancelBtnTextColor="" // 取消按钮文字颜色
  confirmBtnTextColor="" // 确认按钮文字颜色
  pickerFontColor="" // 选择项文字颜色
  pickerFontSize="" // 选择项文字大小
/>

RNInput - Input

RNAngle - 三角形

RNToast - Toast

RNToTop - 返回头部

RNTreeSelect - 树型结构

RNButton - Button

RNCountDown - 倒计时组件

Util

screenUtil - 尺寸适配

方法名|方法|参数 :-|:-:|:-: 字体缩放|setSpText|(size) => {} 大小缩放|scaleSize|(size, allowFontScaling) => {}

isIphoneX - 判断是否是iphoneX系列

screenW - 屏幕宽度

screenH - 屏幕高度