javascript – 什么是使用react-redux与基于事件的第三方库的最佳方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 什么是使用react-redux与基于事件的第三方库的最佳方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1729字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 什么是使用react-redux与基于事件的第三方库的最佳方法](/upload/InfoBanner/zyjiaocheng/767/4e36e0f7105d4933bda19366887791f6.jpg)
将视图连接到不断调度事件的库的最佳方法是什么?我在redux实际示例中看到,最好使用mapDispatchToProps并注入加载操作.在我们的案例中,我们需要监听随时间推移的事件.我以为我们可以使用中间件来做到这一点,但我不是百分百肯定.还有其他选择是在动作创建者本身内进行聆听.
有任何想法吗?
// 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);
// actions.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
}
}
// reducer.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;
}
}
// middleware.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就是你要找的,如果你不想用自制的中间件过度复杂你的应用程序.
内容总结
以上是互联网集市为您收集整理的javascript – 什么是使用react-redux与基于事件的第三方库的最佳方法全部内容,希望文章能够帮你解决javascript – 什么是使用react-redux与基于事件的第三方库的最佳方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。