2

我正在尝试使用 Typescript和withStylesfrom编写一个 React 组件。这两个包装器都是 HOC。@material-ui/corewithTranslationreact-i18next

Typescript 抱怨关于类型的错误。

由于某种原因,这条线不起作用:

export default withTranslation()(withStyles(styles)(HomePage)); // error

但是,如果我只使用 withStyles 或只使用 withTranslation 它可以完美地工作:

export default withTranslation()(HomePage); // ok


export default withStyles(styles)(HomePage); // ok

我知道类型、接口存在问题,或者以这种方式导出我的组件可能有问题。withRouter和 一起使用时遇到了同样的问题withStyles。我通过更改它们在导出行中的顺序解决了错误!(不明白为什么它被解决了 TBH)我看到了一些建议将整个组件包装在下面的解决方案,withStyles但它对我来说似乎很难看。有什么建议吗?

这是错误:

(alias) withStyles<"root", {}, {}>(style: Styles<Theme, {}, "root">, options?: {} | undefined): PropInjector<{
    classes: Record<"root", string>;
}, StyledComponentProps<"root">>
import withStyles

Argument of type 'ComponentType<Pick<IProps, "i18n" | "t"> & StyledComponentProps<"root">>' is not assignable to parameter of type 'ComponentType<WithTranslation>'.
  Type 'ComponentClass<Pick<IProps, "i18n" | "t"> & StyledComponentProps<"root">, any>' is not assignable to type 'ComponentType<WithTranslation>'.
    Type 'ComponentClass<Pick<IProps, "i18n" | "t"> & StyledComponentProps<"root">, any>' is not assignable to type 'ComponentClass<WithTranslation, any>'.
      Types of property 'propTypes' are incompatible.
        Type 'WeakValidationMap<Pick<IProps, "i18n" | "t"> & StyledComponentProps<"root">> | undefined' is not assignable to type 'WeakValidationMap<WithTranslation> | undefined'.
          Type 'WeakValidationMap<Pick<IProps, "i18n" | "t"> & StyledComponentProps<"root">>' is not assignable to type 'WeakValidationMap<WithTranslation>'.
            Types of property 'i18n' are incompatible.
              Type 'Validator<{ changeLanguage: Function; }> | undefined' is not assignable to type 'Validator<i18n> | undefined'.
                Type 'Validator<{ changeLanguage: Function; }>' is not assignable to type 'Validator<i18n>'.
                  Type '{ changeLanguage: Function; }' is missing the following properties from type 'i18n': t, init, loadResources, use, and 28 more.ts(2345)
index.d.ts(80, 3): 'tReady' is declared here.

这是我的组件:

import React, { PureComponent } from "react";
// i18n
import { withTranslation } from "react-i18next";
import { InterfaceI18n } from "../../i18n";
// Stylus
import { WithStyles } from "@material-ui/core";
import withStyles from "@material-ui/core/styles/withStyles";
import styles from "./HomePage.style";

type WrapperPropsStylus = WithStyles<typeof styles>;
interface IProps extends InterfaceI18n, WrapperPropsStylus {}

class HomePage extends PureComponent<IProps> {
  changeLanguage = (lng: string) => {
    const { i18n } = this.props;
    i18n.changeLanguage(lng);
  };
  public render() {
    const { classes, t } = this.props;
    return (
      <div className={classes.root}>
        <div>
          This is the home page (Public page) <br />
        </div>
        {t("Welcome to React")} <br />
        <button onClick={() => this.changeLanguage("de")}>de</button>
        <button onClick={() => this.changeLanguage("en")}>en</button>
      </div>
    );
  }
}

export default withTranslation()(withStyles(styles)(HomePage));
4

1 回答 1

1

好吧,为了解决这个问题,我把 Component 改成了 Hooks。只需使用 Hooks 而不是 Classes Components,使用 TS 就容易多了。

于 2020-07-21T19:31:38.403 回答