🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Redux

Reduxは、JavaScriptアプリケーションの状態を管理するためのオープンソースライブラリです。ReactやAngularで一般的にユーザーインターフェイスの構築に利用されます。

Material-UI

Material-UIは、Material Designを利用可能なオープンソースのReact向けUIコンポーネントキットです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

1367閲覧

React+ReduxにおけるMaterial-UI

退会済みユーザー

退会済みユーザー

総合スコア0

Redux

Reduxは、JavaScriptアプリケーションの状態を管理するためのオープンソースライブラリです。ReactやAngularで一般的にユーザーインターフェイスの構築に利用されます。

Material-UI

Material-UIは、Material Designを利用可能なオープンソースのReact向けUIコンポーネントキットです。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2019/09/07 12:05

編集2019/09/07 13:30

前提・実現したいこと

React+Redux+Material-UIを用いて簡単なアプリケーションを作成しています。
Material-UIのDrawerのopen,closeをReduxで管理しているのですが、ボタンを押しても一向に開いてくれません。
どなたか解決方法のご教授をお願い致します。

該当のソースコード

/** * components/Header.js */ const drawerWidth = 200 // Width for Drawer const styles = theme => ({ root: { flexGrow: 1, zIndex: 1, overflow: 'hidden', position: 'relative', display: 'flex', width: '100%', }, appBar: { position: 'absolute', marginLeft: drawerWidth, [theme.breakpoints.up('md')]: { width: `calc(100% - ${drawerWidth}px)`, }, }, toolbar: theme.mixins.toolbar, navIconHide: { [theme.breakpoints.up('md')]: { display: 'none', }, }, drawerPaper: { width: drawerWidth, [theme.breakpoints.up('md')]: { position: 'relative', }, }, drawerListSubheader: { backgroundColor: theme.palette.background.paper, }, content: { flexGrow: 1, overflowY: 'scroll', backgroundColor: theme.palette.background.default, padding: theme.spacing(3), }, }) class Main extends React.Component { render() { const { classes, theme } = this.props const drawer = ( <div> <List> <ListSubheader className={classes.drawerListSubheader} component="div">First List</ListSubheader> <ListItem button> <ListItemText primary="First List Button" /> </ListItem> </List> <Divider /> <List> <ListSubheader className={classes.drawerListSubheader} component="div">Second List</ListSubheader> <ListItem button> <ListItemText primary="Second List Button" /> </ListItem> </List> </div> ) return ( <div className={classes.root}> <AppBar className={classes.appBar}> <Toolbar> <IconButton color="inherit" // アイコンの色 aria-label="open drawer" // ラベル付け onClick={() => this.props.handleToggleDrawer()} className={classes.navIconHide} > <MenuIcon /> {/* メニューアイコン */} </IconButton> <Typography color="inherit" noWrap> Suggesh </Typography> </Toolbar> </AppBar> <Hidden mdUp> {/* md未満 */} <Drawer variant="temporary" anchor={theme.direction === 'rtl' ? 'right' : 'left'} open={this.props.mobileOpen} onClose={() => this.props.handleToggleDrawer()} classes={{ paper: classes.drawerPaper, }} ModalProps={{ keepMounted: true, // Better open performance on mobile. }} > {drawer} </Drawer> </Hidden> <Hidden smDown implementation="css"> {/* md以上 */} <Drawer variant="permanent" open classes={{ paper: classes.drawerPaper, }} > {drawer} </Drawer> </Hidden> <main className={classes.content}> <div className={classes.toolbar} /> <h1>Hello World</h1> </main> </div> ) } } Main.propTypes = { classes: PropTypes.object.isRequired, theme: PropTypes.object.isRequired, } export default withStyles(styles, { withTheme: true })(Main) /** * containers/HeaderContainer.js /* import { connect } from 'react-redux'; import Header from '../components/Header' import { toggleDrawer } from '../actions/HeaderActions' const mapStateToProps = state => ({ mobileOpen: state.mobileOpen }) const mapDispatchToProps = dispatch => ({ handleToggleDrawer: () => dispatch(toggleDrawer()) }) export default connect(mapStateToProps, mapDispatchToProps)(Header) /** * reducers/HeaderDrawerReducer.js /* import * as actionTypes from '../utils/actionTypes' const initialState = { mobileOpen: false, } export default function HeaderDrawerReducer(state = initialState, action) { switch (action.type) { case actionTypes.TOGGLE_DRAWER: console.log('mobileOpen: ' + !state.mobileOpen) return Object.assign({}, state, { mobileOpen: !state.mobileOpen, }) default: return state } } /** * reducers/index.js /* import { combineReducers } from 'redux'; import HeaderDrawerReducer from './HeaderDrawerReducer'; const reducers = combineReducers({ HeaderDrawerReducer: HeaderDrawerReducer, }); export default reducers; /** * utils/actionTypes.js */ export const TOGGLE_DRAWER = 'TOGGLE_DRAWER'; **ーーー追記ーーー** /** * actions/HeaderActions.js */ import { TOGGLE_DRAWER } from "../utils/actionTypes"; export function toggleDrawer(){ return { type: TOGGLE_DRAWER } } /** * App.js */ import React from 'react'; import CssBaseline from '@material-ui/core/CssBaseline'; import {createStore} from 'redux'; import {Provider} from 'react-redux'; import HeaderContainer from './containers/HeaderContainer'; import reducers from './reducers/index'; const store = createStore(reducers) function App() { return ( <Provider store={store}> <CssBaseline> <HeaderContainer /> </CssBaseline> </Provider> ); } export default App; /** * index.js */ import React from 'react' import ReactDOM from 'react-dom' import App from './App' ReactDOM.render( <App />, document.getElementById('root') )

試したこと

エラーはありません。
また、コンソールにはしっかりmobileOpenの値が出力されています。

ーー追記ーー
App.js で reducers/index.js を読み込むのをやめて、直接reducers/HeaderDrawerReducers を読み込めば適切に動作しました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jun68ykt

2019/09/07 13:05

こんにちは (1) actions/HeaderActions.js の内容(アクションクリエータが書かれているものと思いますが。)も、質問に追記して頂きたいです。 (2) HeaderContainerの動作確認としては、HeaderContainer.js から export しているコンポーネントを たとえば App として、 index.js で import App from 'containers/HeaderContainer' ReactDOM.render( <Provider store={store}> <App /> </Provider>, document.getElementById('root')); といった感じでしょうか? index.js で何か特別なことをやっていれば、 index.js も追記頂ければと思います。
退会済みユーザー

退会済みユーザー

2019/09/07 13:28 編集

こんにちは!ご回答ありがとうございます!追記致しました! その後、「試したこと」にも追記致しましたが、App.js で reducers/index.js を読み込むのをやめて、直接reducers/HeaderDrawerReducers を読み込めば適切に動作しました。 今後Reducerが増えることを予測してreducers/index.jsでcombineReducersしていたのですが、それがよくなかったのでしょうか。Reducer一つではcombineReducersはうまく動かないのでしょうか?
jun68ykt

2019/09/07 13:33

追記ありがとうございます。 追記頂いたのですが、追記頂いた部分が原因ではなさそうでした。申し訳ないです。こうすればうまくいくのでは?と思われた部分を回答しました。
guest

回答1

0

ベストアンサー

こんにちは

以下のように combineReducers しているので、

javascript

1const reducers = combineReducers({ 2 HeaderDrawerReducer: HeaderDrawerReducer, 3});

下記の部分

修正前:

javascript

1const mapStateToProps = state => ({ 2 mobileOpen: state.mobileOpen 3})

を、以下に修正する必要がまずあるかなと思います。

修正後:

javascript

1const mapStateToProps = state => ({ 2 mobileOpen: state.HeaderDrawerReducer.mobileOpen 3})

ご質問の ーー追記ーー を読むと、上記の修正だけで意図通り動くかもしれません。

以上参考になれば幸いです。

投稿2019/09/07 13:30

編集2019/09/07 13:39
jun68ykt

総合スコア9058

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/09/07 13:34

修正したところ正しく動作しました!お忙しい中ありがとうございました!
jun68ykt

2019/09/07 13:37

どういたしまして。 > 正しく動作しました! とのことでよかったです???? combineReducersを使って複数のリデューサーを束ねたときに、state の構造がどうなるかについては https://redux.js.org/api/combinereducers#combinereducersreducers の一番上に出ている例が分かりやすいです。
退会済みユーザー

退会済みユーザー

2019/09/07 16:00

ありがとうございます!上記のサイトで勉強させてもらいます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問