将 react-redux 与基于事件的第三方库一起使用的最佳方法是什么?
What's the best way to use react-redux with event based 3rd party library
将视图连接到持续调度事件的库的最佳方法是什么?我在 redux 真实世界的例子中看到,最好使用 mapDispatchToProps 并注入您的加载操作。在我们的例子中,我们需要侦听随时间推移调度的事件。我认为我们可以使用中间件来做到这一点,但我不是 100% 确定。还有其他选择是在动作创建者本身中进行监听。
有什么想法吗?
//app.jsx
<div>
<MyCollection name="ONE" />
<MyCollection name="TWO" />
</div>
//my-collection.jsx
import {load} from './actions';
class MyCollection extends React.Component {
componentDidMount() {
this.props.load(this.props.name);
}
componentDidUpdate(prevProps) {
if(prevProps.name !== this.props.name) {
this.props.load(this.props.name);
}
}
render() {
return (
<div>{this.props.name}: {this.props.value}</div>
)
}
}
function mapStateToProps(state) {
return {
value: state.value
}
}
const mapDispatchToProps = {
loadAndWatch
}
connect(mapStateToProps, mapDispatchToProps)(MyCollection);
行动.js
import {MyCollection} from '@corp/library';
export function load(name) {
return (dispatch, getState) => {
MyCollection.getValue(name, value => {
dispatch(setValue(name));
})
}
}
export function setValue(name) {
return {
type: 'SET_VALUE',
name
}
}
减速器.js
function reducer(state, action) {
switch(action.type) {
case 'SET_WATCHING':
return Object.assign({}, state, {isWatching: true});
case 'SET_VALUE':
return Object.assign({}, state, {value: action.value});
default:
return state;
}
}
中间件.js
import {setValue} from './actions';
function middleware({dispatch, getState}) {
return next => action => {
switch (action.type) {
case 'SET_VALUE':
next(action);
if (getState().isWatching) {
return;
}
MyCollection.addChangeListener(name, value => {
dispatch(setValue(name))
});
dispatch({type: 'SET_WATCHING'});
}
}
}
我相信 redux-observable 是你正在寻找的,以防你不想用自制的中间件使你的应用程序过于复杂。
相关文章:
- 转义符不能与innerHTML一起使用
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 有条件更新d3.js力图中节点的最佳方法
- 高亮显示与数组字符串一起使用时文本插件中断
- 为react组件传递道具的最佳方式
- 与运行长作业(javascript,node.js)的第三方API同步的最佳实践
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- setTimeout可以与闭包内的函数一起使用吗
- 将依赖外部库的UMD模块与browserfy捆绑在一起
- Highcharts colorsByPoint与系列中的线性渐变一起使用时不起作用
- 将jQuery.ech()方法转换为本地JavaScript抽象的最佳方法是什么
- Angularjs 1.5.x本地化最佳实践
- 存储数据的最佳方式是什么,以便与jquery一起使用
- 将 react-redux 与基于事件的第三方库一起使用的最佳方法是什么?
- 与 API 一起使用时,将 Date 对象存储在数据库中的最佳实践是什么
- 将mongoDB与node.js一起使用的最佳方式是什么
- 在Node js中串在一起的各种DB调用的最佳方法
- 与Mongoose一起使用Promise的最佳实践
- 在 .NET 3.5 中将 ExtJS 与 Asp.net 和 WCF 一起使用的最佳实践是什么?