使用Material UI V1

时间:2017-12-21 16:15:47

标签: javascript reactjs redux react-redux material-ui

我正在利用Redux和Material UI V1做一些根本错误的事情,我正在寻求帮助。我无法成功地将Card组件的宽度设置为75像素。

我们如何使用withStylesconnect将自定义样式传递给我们的组件?我一直在关注Paper组件的Material UI文档中的示例here,但无法成功设置我的UI样式。以下是我的演示文稿和容器组件的代码片段:

容器:

import compose from 'recompose/compose';
import { connect } from 'react-redux';
import { withStyles } from 'material-ui/styles';

import Home from '../components/Home';
import * as homeActions from '../modules/home';

const styles = theme => ({
  root: theme.mixins.gutters({
    width: 75,
  }),
});

const mapStateToProps = (state, ownProps = {}) => {
  return {
    props: {
      classes: styles,
      welcomeMessage: state.home.message || ''
    }
  };
};

const mapDispatchToProps = (dispatch, ownProps = {}) => {
  dispatch(homeActions.loadPage());

  return {
  };
};

export default compose(
  withStyles(styles),
  connect(mapStateToProps, mapDispatchToProps)
)(Home)

表象:

import Card, { CardActions, CardContent, CardMedia } from 'material-ui/Card';
import Button from 'material-ui/Button';
import PropTypes from 'prop-types';
import React from 'react';
import ReactDOM from 'react-dom';
import Typography from 'material-ui/Typography';

import photo from './party.png';

const Component = ({props}) => {
  return (
        <div>
      <Card classes={{
        root: props.classes.card
      }}>
        This is Paper
      </Card>
    </div>
  );
}

Component.propTypes = {
  props: PropTypes.object.isRequired
};

export default Component;

编辑:

我还利用这个SO post来了解Redux和Material UI API如何组合样式。

另外,我没有明确说明这一点,但根据Material UI,所有Paper道具对于Card道具都有效,以防你想知道为什么我引用了Paper文档。

我还替换了以前直接链接到我的项目的代码片段。

1 个答案:

答案 0 :(得分:1)

我认为您的演示组件可以表达自己的风格。

使用withStyles导出您的演示文稿组件:

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

const styles = theme => ({
  root: theme.mixins.gutters({
    width: 75,
  }),
});

const Component = ({ classes }) => {
  return (
    <div>
      <Card className={classes.root}>This is Paper</Card>
    </div>
  );
};

Component.propTypes = {
  classes: PropTypes.shape({
    root: PropTypes.string,
  }).isRequired,
};

export default withStyles(styles)(Component);

然后,在您的容器中,您只需连接演示组件的默认导出:

export default connect(mapStateToProps, mapDispatchToProps)(Home)