react反向继承的高阶组件如何写typescript

发布于 2022-09-12 22:17:05 字数 2168 浏览 13 评论 0

昨天有dalao给了个解决方案,但觉得有点治标不治本,不知有无更好的解决方案。

我想实现的结果是:告知iiHOC作为参数的wrappedComponent组件中含有有somedatadosth等属性。

报错信息是这样的:

    render(){
      // ts报错:类型`typeof iiHOC`上不存在属性`somedata`
      // 运行起来完全没有问题,能正常输出
      console.log(this.somedata);
      return super.render();
    }

完整代码如下:

interface wrppdComp2Props {
  score: number
}

interface wrppdComp2State {
  age: number
}

interface iWrppdComp2 extends React.ComponentClass<wrppdComp2Props, wrppdComp2State> {
  somedata: number
}

function iiHOC(WrappedComponent: iWrppdComp2)  {
  return class iiHOC extends WrappedComponent {

    componentDidMount(){
      console.log('重写了生命周期函数');
    }

    render(){
      // ts报错:类型`typeof iiHOC`上不存在属性`somedata`
      // 运行起来完全没有问题,能正常输出
      console.log(this.somedata);
      return super.render();
    }
  }
}

// 反向继承高阶组件
export class MyDiv2 extends React.Component<wrppdComp2Props, wrppdComp2State>{

  constructor(props: wrppdComp2Props) {
    super(props);
    this.state = {
      age: 18
    };
  }

  somedata:number = 10010;

  dosth(){
    console.log('i want to do sth');
  }

  componentDidMount() {
    console.log('childComp was mount');
  }

  render() {
    console.log(this.somedata);
    return <div>
      <p>
        一层套娃
        <span>二层套娃</span>
      </p>
    </div>
  }
}

const MyiiHoc = iiHOC(MyDiv2);

export class ReactHoc extends Component<any, any> {

  render() {
    return <div>
      <MyiiHoc score={16} />
    </div>
  }
}

我也曾试过这样写:

interface iWrppdComp2 extends React.ComponentClass<wrppdComp2Props, wrppdComp2State> {
  new () {
    somedata: number;
  }
}

结果如下:
image
或者比较暴力的方法:

function iiHOC(WrappedComponent: typeof MyDiv2)  {
  // ...
}

这倒是比较完美,但是失去了高阶组件复用的价值......

求一个解决方案,或关于反向继承实现的高阶组件的typescript的编程文章或实例,谢谢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

女尤 2022-09-19 22:17:05
import React from 'react'
interface wrppdComp2Props {
  score: number
}

interface wrppdComp2State {
  age: number
}

interface iWrppdComp2Constructor {
  new (props: wrppdComp2Props): iWrappdComp2Instance;
}

interface iWrappdComp2Instance extends React.Component<wrppdComp2Props, wrppdComp2State> {
  somedata: number;
}

function iiHOC(WrappedComponent: iWrppdComp2Constructor)  {
  return class iiHOC extends WrappedComponent {

    componentDidMount(){
      console.log('重写了生命周期函数');
    }

    render(){
      // ts报错:类型`typeof iiHOC`上不存在属性`somedata`
      // 运行起来完全没有问题,能正常输出
      console.log(this.somedata);
      return super.render();
    }
  }
}

// 反向继承高阶组件
export class MyDiv2 extends React.Component<wrppdComp2Props, wrppdComp2State>{

  constructor(props: wrppdComp2Props) {
    super(props);
    this.state = {
      age: 18
    };
  }

  somedata:number = 10010;

  dosth(){
    console.log('i want to do sth');
  }

  componentDidMount() {
    console.log('childComp was mount');
  }

  render() {
    console.log(this.somedata);
    return <div>
      <p>
        一层套娃
        <span>二层套娃</span>
      </p>
    </div>
  }
}

const MyiiHoc = iiHOC(MyDiv2);

export class ReactHoc extends React.Component<any, any> {

  render() {
    return <div>
      <MyiiHoc score={16} />
    </div>
  }
}

ps:你这个命名规范点,首字母大写

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文