react-native DatePicker日期选择组件的实现

本教程的实现效果如下:

为了实现其淡入/淡出的覆盖效果, 还有取消按钮, 在此用了一个三方的组件, 大家可以先安装一下:

三方组件的地址:https://github.com/eyaleizenberg/react-native-custom-action-sheet (可以看看,也可以直接按我的步骤走)

1. 在terminal的该工程目录下运行: npm install react-native-custom-action-sheet --save

2. 然后运行: npm start

3. 具体实现代码如下:

import React, { Component } from ‘react‘;
import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  TouchableHighlight,
  DatePickerIOS
} from ‘react-native‘;

//这是一个三方组件 github地址:https://github.com/eyaleizenberg/react-native-custom-action-sheet
var CustomActionSheet = require(‘react-native-custom-action-sheet‘);

class Demo extends Component {

  state = {
    datePickerModalVisible: false,  //选择器显隐标记
    chooseDate: new Date()  //选择的日期
  };

  _showDatePicker () { //切换显隐标记
    this.setState({datePickerModalVisible: !this.state.datePickerModalVisible});
  };

  _onDateChange (date) {  //改变日期state
    alert(date);  //弹出提示框: 显示你选择日期
    this.setState({
      chooseDate: date
    });
  };

  render() {

    let datePickerModal = (   //日期选择器组件 (根据标记赋值为 选择器 或 空)
      this.state.datePickerModalVisible ?
      <CustomActionSheet
        modalVisible={this.state.datePickerModalVisible}  //显隐标记
        onCancel={()=>this._showDatePicker()}>  //点击取消按钮 触发事件
          <View style={styles.datePickerContainer}>
            <DatePickerIOS
              mode={"datetime"}   //选择器模式: ‘date‘(日期), ‘time‘(时间), ‘datetime‘(日期和时间)
              minimumDate={new Date()}  //最小时间 (这里设置的是当前的时间)
              minuteInterval={30} //最小时间间隔 (这里设置的是30分钟)
              date={this.state.chooseDate}  //默认的时间
              onDateChange={this._onDateChange.bind(this)}  //日期被修改时回调此函数
            />
            </View>
       </CustomActionSheet> : null
    );

    return (
      <View style={styles.container}>
        <TouchableHighlight
          style={{backgroundColor:‘cyan‘, padding:5}}
          onPress={()=>this._showDatePicker()}  //按钮: 点击触发方法
          underlayColor=‘gray‘
          >
          <Text >show DatePick</Text>
        </TouchableHighlight>
        {datePickerModal}  //日期选择组件
      </View>
    );
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: ‘center‘,
    alignItems: ‘center‘,
    backgroundColor: ‘#F5FCFF‘,
  },
  datePickerContainer: {
    flex: 1,
    borderRadius: 5,
    justifyContent: ‘center‘,
    alignItems: ‘center‘,
    backgroundColor: ‘white‘,
    marginBottom: 10,
  },
});

AppRegistry.registerComponent(‘Demo‘, () => Demo);

写好了,在terminal中运行:react-native run-ios 就能看到效果了

时间: 2024-08-01 23:01:41

react-native DatePicker日期选择组件的实现的相关文章

推荐 11 款 React Native 开源移动 UI 组件

推荐 11 款 React Native 开源移动 UI 组件 oschina 发布于 10个月前,共有 14 条评论 本文推荐 11 个非常棒的 React Native 开源组件,希望能给移动应用开发者提供帮助. React Native 是近期 Facebook 基于 MIT 协议开源的原生移动应用开发框架,已经用于 Facebook 的生产环境.React Native 可以使用最近非常流行的 React.js 库来开发 iOS 和 Android 原生 APP. 1. iOS 表单处理

日期选择组件

在开发过程中,偶尔会碰到相同内容多处使用的情况.同一种处理办法,却要相互间互不影响. 以下是个人在项目开发中碰到的一个日期选择组件.HTML5提供了input type = "date",但是由于其兼容性,连IE10都无法启用.所以必须考虑使用其它办法.在此之前考虑了JQ UI的日期时间选择.但介于文件超过400KB,这对于一般小型网站,流量资源十分珍贵的情况下还是自己开发一个直接.简单.轻巧. JS代码如下: 使用方式,十分简单, var b = new A($('#two'));

React Native 调用原生Android组件

在如今的App中,已经有成千上万的原生UI部件了--其中的一些是平台的一部分,另一些可能来自于一些第三方库,而且可能你自己还收藏了很多.React Native已经封装了大部分最常见的组件,譬如ScrollView和TextInput,但不可能封装全部组件.而且,说不定你曾经为自己以前的App还封装过一些组件,React Native肯定没法包含它们.幸运的是,在React Naitve应用程序中封装和植入已有的组件非常简单. 比如WebView,官方并没有提供Android端的实现,那么我们现

Android React Native使用原生UI组件

Android React Native 已经将几个常用的原生组件进行了封装,比如 ScrollView 和 TextInput,但是并不是所有系统的原始组件都被封装了,因此有的时候我们不得不自己动手封装一下,从而能够使用那些React Native没有为我们封装的原生组件,比如WebView,官方并没有提供Android端的实现,那么我们现在就动手封装一下WebView. 之前写过一篇文章Android React Native使用原生模块,而使用原生UI组件的方法和使用原生模块的方法十分类似

React Native知识5-Touchable类组件

React Native 没有像web那样可以给元素绑定click事件,前面我们已经知道Text组件有onPress事件,为了给其他组件 也绑定点击事件,React Native提供了3个组件来做这件事. 1.TouchableHighlight:高亮触摸,用户点击时,会产生高亮效果. 2.TouchableOpacity:透明触摸.用户点击时,点击的组件会出现透明效果. 3.TouchableWithoutFeedback:无反馈性触摸.用户点击时无任何视觉效果. 注意:只支持一个子节点,如果

DatePicker - 日期选择插件

在一些WEB系统中,日期选择插件必不可少的功能,今天为大家分享几个不错的日期选择插件.希望对大家有所帮助. 1)My97DatePicker是一个更全面,更人性化,并且速度一流的日期选择控件.具有强大的日期范围限制功能:自定义事件和丰富的API库:多语言支持和自定义皮肤支持:跨无限级框架显示和自动选择显示位置. 主页: http://www.my97.net/dp/index.asp 演示地址: http://www.my97.net/dp/demo/index.htm 2)Date Range

react native 基础按钮的组件

/** * Created by zmis2 on 2016/11/18. */import React,{Component} from 'react';import { Text, View, StyleSheet, TouchableOpacity,} from 'react-native'; export default class Button extends Component { //构造 constructor(props) { super(props); //初始状态 this

React Native 之 定义的组件 (跨文件使用)

哈哈的~~~今天介绍的是自定义组件 然后去使用这个组件,让这个组件传递这各种文件之间  哈哈  下面开始吧!!!! 我们所要创建的是一个自定义的Button,先创建一个js文件起名为MyButton, 且触摸后的底色.触发事件响应的函数. 图片资源.以及图片大小都是根据传过来的值确定的.(所传递进来的参数决定) ok!!下面我们需要在MyButton.js 这个文件中添加一些原生的控件(组件) import React, { AppRegistry, Component, Image, Touc

8、手把手教React Native实战之ReactJS组件生命周期

1.创建阶段 getDefaultProps:处理props的默认值 在React.createClass调用 2.实例化阶段 React.render(<HelloMessage 启动之后 getInitialState.componentWillMount.render.componentDidMount state:组件的属性,主要是用来存储组件自身需要的数据,每次数据的更新都是通过修改state属性的值,ReactJS内部会监听state属性的变化,一旦发生变化的话,就会主动触发组件的r