react+mobx 编写 withStoreHistory 装饰器
Posted ajanuw
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react+mobx 编写 withStoreHistory 装饰器相关的知识,希望对你有一定的参考价值。
主要作用是向store里面注入一个history对象,方便story里面的函数调用
function withStoreHistory(storeName) {
if (!storeName) return console.error(`必须输入一个查询数据的store`);
return function(Target) {
class WithStoreHistory extends Component {
componentDidMount() {
const { history } = this.props;
const store = this.props[storeName];
store.history = history;
}
render() {
return <Target {...this.props} />;
}
}
return WithStoreHistory;
};
}
使用
需要在inject调用后才能获取到store的数据,所以写在inject下面
const MERCHANTSTORE = "merchantStore";
@inject(MERCHANTSTORE)
@withStoreHistory(MERCHANTSTORE)
@observer
class BusinessEntrance extends Component {
render() {
return (
<div>...</div>
);
}
}
函数中使用
@action.bound
handleSettingData() {
this.history.push("/merchants_settled");
}
以上是关于react+mobx 编写 withStoreHistory 装饰器的主要内容,如果未能解决你的问题,请参考以下文章