Use*_*321 4 jsx reactjs redux react-redux react-router-redux
我想在组件中触发一个动作。这是一个演示组件,不需要Redux感知。路由器的实现是通过react-router-redux完成的。
main.js:
let store = createStore(rootReducer)
const history = syncHistoryWithStore(hashHistory, store)
class RenderClass extends Component {
render() {
return (
<Provider store={store}>
<Router history={history}>
<Route path="/" component={MainLayout}>
<Route name="employees" path="/employees" url="http://localhost:8080/" component={EmployeeTable}></Route>
<Route name="personalInformation" path="/personalInformation/:employeeId" url={URI} component={PersonalInformation} />
.....
</Route>
<Router>
</Provider>
);
}
}
Run Code Online (Sandbox Code Playgroud)
App.jsx:
import * as Actions from './action-creator';
const MainLayout = React.createClass({
render: function() {
const { dispatch, list } = this.props;
let actions = bindActionCreators(Actions, dispatch);
console.log(actions);
return (
<div className="wrapper">
<Header actions={actions} list={list} params={this.props.params} />
{React.cloneElement(this.props.children, this.props)}
</div>
)
}
});
function select(state) {
return {
list: state.listingReducer
}
}
export default connect(select)(MainLayout);
Run Code Online (Sandbox Code Playgroud)
header.js:
define(
[
'react',
'jquery',
'appMin'
],
function (React, $) {
var Link = require('reactRouter').Link;
var Header = React.createClass({
handleClick: function () {
//Action called here
this.props.actions.listEmployees();
},
render: function () {
return (
<ul className="sidebar-menu">
<li>
<Link to={'/employees'} onClick={this.handleClick}><i className="fa fa-home"></i>Employees</Link>
</li>
</ul>
);
}
});
return Header;
}
)
Run Code Online (Sandbox Code Playgroud)
employee.js:
define(
[
'react',
'jquery',
'appMin'
],
function (React, $) {
var EmployeeTable = React.createClass({
render: function () {
if (this.props.list != undefined) {
var listItems = this.props.list.map(function (listItem) {
return (
<tr key={listItem.id}>
<td> {listItem.name}</td>
<td><Link to={'/personalInformation/' + employee.id} onClick={this.props.actions.displayPersonalInformation(employee.id)}>Personal Information</Link></td>
......
</tr>
);
}, this);
})
}
return (
<table>
<tbody>
{listItems}
</tbody>
</table>
);
}
})
}
)
Run Code Online (Sandbox Code Playgroud)
action-creator.js:
export function listEmployees() {
return {
type: types.LIST_EMPLOYEES
};
}
export function displayPersonalInformation() {
return {
type: types.DISPLAY_PERSONAL_INFORMATION
};
}
reducer.js:
function addEmployee(state, action) {
switch (action.type) {
case types.LIST_EMPLOYEES:
return {"id":"1", "name":"Stackoverflow"}
default:
return state
}
}
function listingReducer(state = [], action) {
switch (action.type) {
case types.LIST_EMPLOYEES:
return [
...state,
addEmployee(undefined, action)
]
case types.DISPLAY_PERSONAL_INFORMATION:
return // Gets personal Information
default:
return state;
}
}
const rootReducer = combineReducers({
listingReducer
})
export default rootReducer
Run Code Online (Sandbox Code Playgroud)
道具不会包含动作,因为我没有将其绑定到道具。我尝试在App.js中编写mapStateToProps和mapDispatchToProps,如下所示:
function mapStateToProps(state) {
return {
list: state.list
}
}
function mapDispatchToProps(dispatch) {
return { actions: bindActionCreators({ actionCreators }, dispatch) }
}
Run Code Online (Sandbox Code Playgroud)
导出默认的connect(mapStateToProps,mapDispatchToProps)(MainLayout)我得到调度不是函数错误。错误语句实际上听起来像是stackoverflow中的重复问题,但是我也想知道为什么我使用mapDispatchToProps的目的也是正确的。提前致谢。
所以,从我了解你正在使用export default connect(mapStateToProps, mapDispatchToProps)(MainLayout),并试图打电话给dispatch在MainLayout。
因此,如果您看到react-redux文档,则可以通过以下方式调用connect:
connect()(//Component) ->调度将作为道具传递 connect(mapStateToProps)(//Component) ->调度将作为道具传递connect(mapStateToProps,mapDispatchToProps)(//Component)-> 调度不会作为道具传递给您的组件在方案3中,行为是这样的,因为mapDispatchToProps已经可以使用调度功能。因此,您可以绑定您的函数以进行分派mapDispatchToProps,然后将此函数传递给您的组件。
例
您要调度的函数是,dispatchMe()并且该函数dispatchMe2()调用称为的操作dispatchAction。所以你mapDispatchToProps会像:-
function mapDispatchToProps(dispatch){
return {
dispatchMe : () => {
dispatch(dispatchAction())
},
dispatchMe2 : () => {
dispatch(dispatchAction2())
}
}
}
Run Code Online (Sandbox Code Playgroud)
现在,您可以在组件中通过dispatchMe并在需要时调用它。
你可以在这里阅读更多信息
| 归档时间: |
|
| 查看次数: |
6234 次 |
| 最近记录: |