首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我正在尝试将此React类组件更改为功能组件

我正在尝试将此React类组件更改为功能组件
EN

Stack Overflow用户
提问于 2020-05-02 17:24:16
回答 2查看 36关注 0票数 0

我想这样做的原因是,我习惯了函数组件,而我的其余代码都是用函数组件编写的,所以我想保持这种方式。我实际上从来没有学习过类组件(我还是个编程新手),我们只是开始使用函数组件,可能是因为React Hooks,虽然我在网上读过一些东西,但我很难尝试转换它。这是我试图转换的代码:

代码语言:javascript
复制
import React, { Component } from 'react';
import Calendar from 'react-calendar';
 
class MyApp extends Component {
  state = {
    date: new Date(),
  }
 
  onChange = date => this.setState({ date })
 
  render() {
    return (
      <div>
        <Calendar
          onChange={this.onChange}
          value={this.state.date}
        />
      </div>
    );
  }
}

export default Calendar;

我只设法将其中的一部分转换为如下所示的功能组件:

代码语言:javascript
复制
import React {useState} from "react";

import Calendar from "react-calendar";

export default function Calendar () {
    const[date, setDate] = useState({date: new Date()})

我甚至不确定我开始的是不是正确的,但这就是我到目前为止关于转换的全部。我不知道如何转换剩下的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-05-02 17:40:25

代码语言:javascript
复制
import React, { useState } from 'react';
import Calendar from 'react-calendar';

export default () => {
  const[date, setDate] = useState({date: new Date()});
  return (
    <div>
      <Calendar
        onChange={date => setDate({ date })}
        value={date}
      />
    </div>
  );
}
票数 2
EN

Stack Overflow用户

发布于 2020-05-02 17:42:31

代码语言:javascript
复制
import React, { useState} from 'react';
import Calendar from 'react-calendar';

 const Calendar = () => {
 const[date, setDate] = useState({new Date()});

  onChange = date => setDate(date);

  render() {
    return (
      <div>
        <Calendar
          onChange={this.onChange}
          value={date}
        />
      </div>
    );
  }
}

export default Calendar;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61557087

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档