热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

通用无状态组件的类型是什么?或者在typescript中扩展泛型函数接口以进一步通用?

如何解决《通用无状态组件的类型是什么?或者在typescript中扩展泛型函数接口以进一步通用?》经验,为你挑选了3个好方法。

问题:界面Stateless Functional Component给出为

interface SFC

{ (props: P & { children?: ReactNode }, context?: any): ReactElement | null; propTypes?: ValidationMap

; }

我的组件的prop类型也是通用的:

interface Prop{
    num: V;
}

如何正确定义我的组件?如:

const myCom: SFC> = (props: Prop)=> 
test

在给出了一个错误character 27的是Cannot find name 'T'

这是:Modifiedcript Playground的修改示例

MyFindings:

1:Typescript 2.9.1支持有状态通用组件:http://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-9.html#generic-type-arguments-in-jsx-elements

class myCom extends React.Component, any> {
   render() {
      return 
test
; } }

2:扩展SFC以创建一个新接口,如下面的答案中所述,将使组件的prop类型为any: Typescript使用我不想要的泛型参数/返回类型的React无状态函数.我想为我的道具提供合适的类型



1> jmattheis..:

你不能使用这样的泛型:

const myCom: SFC> = (props: Prop)=> 
test

TypeScript规范说明:

形式的构造

 ( ... ) => { ... }

可以解析为箭头函数表达式,其类型参数或类型断言应用于没有类型参数的箭头函数.

资源; Microsoft/TypeScript spec.md

您的声明与TypeScript规范中定义的模式不匹配,因此它不起作用.

但是,您可以不使用SFC接口,只需自己声明.

interface Prop {
    num: V;
}

// normal function
function Abc(props: Prop): React.ReactElement> {
    return 
; } // const lambda function const Abc: (p: Prop) => React.ReactElement> = (props) => { return
}; export default function App() { return ( num={1} /> num="abc" /> num={1} /> // string expected but was number ); }



2> 小智..:

有一种模式可以通过在组件外部声明通用组件类型别名,然后在需要时简单地声明它来缓解此问题。

虽然不那么漂亮,但是仍然可以重用和严格。

interface IMyComponentProps {
  name: string
  type: T
}

// instead of inline with component assignment
type MyComponentI = React.FC>

const MyComponent: MyCompOnentI= props => 

Hello

const TypedCompOnent= MyComponent as MyComponentI



3> chris..:

工厂模式:

import React, { SFC } from 'react';

export interface GridProps {
  data: T[];
  renderItem: (props: { item: T }) => React.ReactChild;
}

export const GridFactory = (): SFC> => () => {
  return (
    
...
); }; const Grid = GridFactory();


推荐阅读
  • node.jsrequire和ES6导入导出的区别原 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 本文介绍了如何使用vue-awesome-swiper组件,包括在main.js中引入和使用swiper和swiperSlide组件,以及设置options和ref属性。同时还介绍了如何在模板中使用swiper和swiperSlide组件,并展示了如何通过循环渲染swipes数组中的数据,并使用picUrl属性显示图片。最后还介绍了如何添加分页器。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了如何使用python从列表中删除所有的零,并将结果以列表形式输出,同时提供了示例格式。 ... [详细]
  • ALTERTABLE通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。语法ALTERTABLEtable{[ALTERCOLUMNcolu ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
author-avatar
手机用户2502901265_642
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有