问答

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

作者:admin 2021-05-05 我要评论

昨天有dalao给了个 解决方案 ,但觉得有点治标不治本,不知有无更好的解决方案。 我想实现的结果是:告知iiHOC作为参数的 wrappedComponent 组件中含有有 someda...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

昨天有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的编程文章或实例,谢谢。

###
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:你这个命名规范点,首字母大写

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • react反向继承的高阶组件如何写typescr

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

  • 公平锁,但是输出的顺序不是t1,t2,t3,

    公平锁,但是输出的顺序不是t1,t2,t3,

  • 求助!!导航栏需要完成不规则图片拼接

    求助!!导航栏需要完成不规则图片拼接

  • 关于宝塔面板建多个网站的问题

    关于宝塔面板建多个网站的问题

腾讯云代理商
海外云服务器