mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-05 05:28:20 +08:00
40 lines
758 B
TypeScript
40 lines
758 B
TypeScript
export interface Store {
|
|
setState: (partial: Object) => void;
|
|
getState: () => any;
|
|
subscribe: (listener: () => void) => () => void;
|
|
}
|
|
|
|
export default function createStore(initialState: object): Store {
|
|
let state = initialState;
|
|
const listeners: any[] = [];
|
|
|
|
function setState(partial: object) {
|
|
state = {
|
|
...state,
|
|
...partial,
|
|
};
|
|
for (let i = 0; i < listeners.length; i++) {
|
|
listeners[i]();
|
|
}
|
|
}
|
|
|
|
function getState() {
|
|
return state;
|
|
}
|
|
|
|
function subscribe(listener: () => any) {
|
|
listeners.push(listener);
|
|
|
|
return function unsubscribe() {
|
|
const index = listeners.indexOf(listener);
|
|
listeners.splice(index, 1);
|
|
};
|
|
}
|
|
|
|
return {
|
|
setState,
|
|
getState,
|
|
subscribe,
|
|
};
|
|
}
|