Я экспериментирую с API реагирующего контекста, и это код, над которым я работаю:
import * as React from 'react';
interface ProviderState {
themeColor: string;
}
interface UpdateStateArg {
key: keyof ProviderState;
value: string;
}
interface ProviderStore {
state: ProviderState;
update: (arg: UpdateStateArg) => void;
}
const Context = React.createContext({} as ProviderStore);
class Provider extends React.Component<{}, ProviderState> {
readonly state = {
themeColor: 'red'
};
private update = ({ key, value }: UpdateStateArg) => {
this.setState({ [key]: value });
}
render() {
const store: ProviderStore = {
state: this.state,
update: this.update
};
return (
<Context.Provider value={store}>
{this.props.children}
</Context.Provider>
);
}
}
export { Provider };
«Провайдер» в методе рендеринга выдает следующую ошибку:
"JSX element type 'ReactElement<any> | null' is not a constructor function for JSX elements.Type 'null' is not assignable to type 'ElementClass"
В файле декларации реагирования 'Provider' был объявлен, и я думаю, что он был объявлен правильно, или я могу ошибаться!
Я использую следующие версии:
react: "^16.5.0"
react-dom: "^16.5.0"
@types/react: "^16.4.7"
@types/react-dom: "^16.0.7"