javascript - 将 Material UI 函数转换为类

标签 javascript reactjs material-ui

如何将 React 函数转换为类?我不明白如何更新函数中的 const { classes } = props; 以供类使用。这是 Material UI 中的按钮功能:https://material-ui-next.com/demos/buttons/

import React from 'react';
import PropTypes from 'prop-types';
import { withStyles } from 'material-ui/styles';
import Button from 'material-ui/Button';

const styles = theme => ({
  button: {
    margin: theme.spacing.unit,
  },
  input: {
    display: 'none',
  },
});

function RaisedButtons(props) {
  const { classes } = props;
  return (
    <div>
      <Button variant="raised" className={classes.button}>
        Default
      </Button>
      <Button variant="raised" color="primary" className={classes.button}>
        Primary
      </Button>
      <Button variant="raised" color="secondary" className={classes.button}>
        Secondary
      </Button>
      <Button variant="raised" color="secondary" disabled className={classes.button}>
        Disabled
      </Button>
      <input
        accept="image/*"
        className={classes.input}
        id="raised-button-file"
        multiple
        type="file"
      />
      <label htmlFor="raised-button-file">
        <Button variant="raised" component="span" className={classes.button}>
          Upload
        </Button>
      </label>
    </div>
  );
}

RaisedButtons.propTypes = {
  classes: PropTypes.object.isRequired,
};

export default withStyles(styles)(RaisedButtons);

这是我对 React 类组件的转换。它目前给我一条错误消息 'classes' is not defined no-undef 因为我缺少 classes = props 部分。

import React, { Component } from 'react';
import Button from 'material-ui/Button';
import MuiThemeProvider from 'material-ui/styles/MuiThemeProvider';
import MyTheme from './MyTheme';
import './App.css';
import { withStyles } from 'material-ui/styles';
import PropTypes from 'prop-types';


const styles = theme => ({
  button: {
    margin: theme.spacing.unit,
  },
  input: {
    display: 'none',
  },
});


class App extends Component {
  constructor(props)
  {
    super(props);
  }  

  render() {
    return (
      <MuiThemeProvider theme={MyTheme}>
          <Button variant="raised" >
          Default
          </Button>
          <Button variant="raised" color="primary" className={classes.button}>
          Primary
          </Button>
          <Button variant="raised" color="secondary" className={classes.button} >
          Secondary
          </Button>
          <Button variant="raised" color="secondary" className={classes.button}>
          Disabled
          </Button>
          <input
              accept="image/*"
              className={classes.input}
              id="raised-button-file"
              multiple
              type="file"
          />
          <label htmlFor="raised-button-file">
          <Button variant="raised" component="span" >
            Upload
          </Button>
          </label>
      </MuiThemeProvider>
      );
  }
}

App.propTypes = {
  classes: PropTypes.object.isRequired,
};

export default withStyles(styles)(App);

最佳答案

只需将其添加到渲染中,就像这样(将其更改为 this.props):

  render() {
    const { classes } = this.props;
    return (

关于javascript - 将 Material UI 函数转换为类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50067852/

相关文章:

javascript - 如何在 Typescript 中声明 NPM 的模块公共(public)类型定义

javascript函数参数命名要求

javascript - WKScriptMessage.body 导致 EXC_BAD_ACCESS

javascript - 如何保存 Api 调用的响应状态?

node.js - 如何将背景照片放入其中一个盒子中 React,尝试了所有方法?

reactjs - 用户未登录时重定向

reactjs - Material UI自动完成自定义renderInput

Javascript onclick 事件不起作用

css - 如何将模态与 Material ui 上的过渡居中并使其响应?

javascript - React Search 标题结果和 Pagination Material UI