javascript - 在单个 onChange 上设置日期选择器的值

标签 javascript reactjs datetime onchange

我正在尝试为两种不同的输入类型设置日期。我尝试为两个输入事件处理程序调用不同的函数,并且它有效。但我想用更简洁的方式来管理输入日期。我尝试调用单个 onChange() 的不同方法似乎并没有改变我的输入框值。

这是我的代码:

import React, { Component } from "react";
import axios from "axios";

export default class DatePage extends Component {
  constructor() {
    super();
    this.state = {
      startDate: '',
      endDate: '',
      clicked: false
    };
  }

  componentDidMount() {

    this.setDate();



    this.setState({
        clicked: true
      });
  }

  setDate = (e) => {

    if (this.state.clicked !== true) 
    {
      var date = new Date();

      var newdate =
        date.getFullYear() + "-" + ("0" + (date.getMonth() + 1)) + "-" + date.getDate();

      this.setState({
        startDate: newdate,
        endDate: newdate,
        clicked: false
      });
    } 

    else 
    {

        this.setState({
            [e.target.name]: e.target.value
        });
    }
  };

  render() {
    return (
      <div>

        <label>From</label>
        <input
          type="date"
          name="startdate"
          value={this.state.startDate}
          onChange={this.setDate}

        />

        <label>To</label>
        <input
          type="date"
          name="enddate"
          value={this.state.endDate}
          onChange={this.setDate}
        />
      </div>
    );
  }
}

默认情况下,我设置当前日期并更改所选日期

最佳答案

您需要更正表单中的姓名。

来自: 名称=“开始日期”名称=“开始日期”

另外,这里: 名称=“结束日期”名称=“结束日期”

关于javascript - 在单个 onChange 上设置日期选择器的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56341312/

相关文章:

python - 在 django 模型中保存 datetimefiled,int() 参数必须是字符串或数字

javascript - 如何让网页显示的数据发生变化时不滚动到顶部

javascript - 如何正确调用由 filepicker 触发的 onChange 事件?

javascript - 在 react 18 中使用 makeStyles Material UI 没有结果

javascript - 如何在服务器端渲染图像?

python - pandas-更改重新采样时间序列的开始和结束日期

javascript - PhoneGap Javascript 代码未显示

javascript - 导轨 3 : Omniauth-Facebook: Won't load in a popup

javascript - Webpack + React : pass commit SHA from webpack to JS

java - 用Java计算日期和时间差