gpt4 book ai didi

javascript - 在 Typescript 中扩展基类属性

转载 作者:数据小太阳 更新时间:2023-10-29 04:45:14 30 4
gpt4 key购买 nike

我正在尝试为 ReactReduxForm 的 Control 组件创建一个包装类以添加额外的功能。这是基类/组件定义:

export class Control<T> extends React.Component<ControlProps<T>, {}> {
static custom: React.ComponentClass<ControlProps<HTMLInputElement>>;
static input: React.ComponentClass<ControlProps<HTMLInputElement>>;
static text: React.ComponentClass<ControlProps<HTMLInputElement>>;
static textarea: React.ComponentClass<ControlProps<HTMLTextAreaElement>>;
static radio: React.ComponentClass<ControlProps<HTMLInputElement>>;
static checkbox: React.ComponentClass<ControlProps<HTMLInputElement>>;
static file: React.ComponentClass<ControlProps<HTMLInputElement>>;
static select: React.ComponentClass<ControlProps<HTMLSelectElement>>;
static reset: React.ComponentClass<ControlProps<HTMLButtonElement>>;
static button: React.ComponentClass<ControlProps<HTMLButtonElement>>;
}

我想为所有类型的控件(例如输入、文本、textarea 等)覆盖 onKeyPress 功能,这些控件是 Control 基类的静态属性/组件。

这是我的派生类的骨架定义:

import * as React from "react";
import { Control } from "react-redux-form";

export class CustomControl<T> extends Control<T> { }

我希望将以下功能应用到 CustomControl 的所有控件类型(例如文本、选择等):

  onKeyPress(e: any) {
if (e.key === "Enter") {
e.preventDefault();
}
}

如何使用我的 `onKeyPress() 功能?

最佳答案

而不是扩展 ControlCustomControl你应该把它包起来。

您真正想要做的是修改 render() Control的方法|并添加自定义 onKeyPress .扩展 Control 的问题是你只能override Control的渲染方法,而不是对其进行更改。

但是,如果您包装 Control组件与您自己的组件,您能够以您希望的方式影响它。

如果您查看 ControlProps<T> 的定义你会看到这个:

export interface ControlProps<T> extends React.HTMLProps<T> {

因为它扩展了React.HTMLProps它支持 onKeyPress方法作为 Prop 。

如果我们将所有这些信息结合在一起,您可以执行以下操作:

import * as React from "react";
import { Control, ControlProps } from "react-redux-form";

export class CustomControl<T> extends React.Component<ControlProps<T>> {

onKeyPress(e: any) {
if (e.key === "Enter") {
e.preventDefault();
}
}

render() {
return <Control {...this.props} onKeyPress={e => this.onKeyPress(e)} />;
}
}

请注意,上面的实现将完全覆盖任何 onKeyPress作为 Prop 传递给 CustomControl赞成您的习惯onKeyPress .

如果您还想调用任何 onKeyPress作为 Prop 传递,您可以将以下内容添加到自定义 onKeyPress 的底部功能:

// After custom logic call any onKeyPress passed to this
this.props.onKeyPress && this.props.onKeyPress(e);

关于javascript - 在 Typescript 中扩展基类属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48407545/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com