首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

typescript:`{ key ():类型}` vs `{ key:() =>类型}`

typescript:{ key (): 类型} vs { key: () => 类型}

这两种写法都是 TypeScript 中定义函数类型的方式,它们的区别在于函数的定义方式不同。

  1. { key (): 类型}:这种写法表示 key 是一个函数,没有参数,返回类型为 类型。这种写法适用于不需要参数的函数,例如:
代码语言:txt
复制
const obj = {
  sayHello(): string {
    return "Hello";
  }
};

在这个例子中,obj 对象中的 sayHello 方法没有参数,返回类型为 string

  1. { key: () => 类型}:这种写法表示 key 是一个函数,没有参数,返回类型为 类型。这种写法适用于不需要参数的函数,例如:
代码语言:txt
复制
const obj = {
  sayHello: (): string => {
    return "Hello";
  }
};

在这个例子中,obj 对象中的 sayHello 方法没有参数,返回类型为 string。注意,这里使用了箭头函数的语法。

总结:

  • { key (): 类型}{ key: () => 类型} 都表示定义一个没有参数的函数,返回类型为 类型
  • { key (): 类型} 是传统的函数定义方式。
  • { key: () => 类型} 是使用箭头函数的函数定义方式。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云函数计算(云函数):https://cloud.tencent.com/product/scf
  • 腾讯云云开发(云开发):https://cloud.tencent.com/product/tcb
  • 腾讯云容器服务(TKE):https://cloud.tencent.com/product/tke
  • 腾讯云数据库(TencentDB):https://cloud.tencent.com/product/cdb
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能(AI):https://cloud.tencent.com/product/ai
  • 腾讯云物联网(IoT):https://cloud.tencent.com/product/iot
  • 腾讯云移动开发(移动开发):https://cloud.tencent.com/product/mobdev
  • 腾讯云区块链(BCS):https://cloud.tencent.com/product/bcs
  • 腾讯云游戏多媒体(GME):https://cloud.tencent.com/product/gme
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

TypeScript 类型体操:提取对象指定 key 并设置为必填

今天我们来做一道 TypeScript 类型编程题。 我们需要实现一个 RequiredPick 类,从一个对象类型中提取指定的 key 生成新的对象类型,并将它的所有 key 设置为必填。...Pick 我们容易想到 Pick 的实现,Pick 是 TypeScript 内置的一个高级类型。这个类型的实现在我以前的文章《类型体操:探究 TypeScript 内置高级类型》有讲解过。...T 和 K,K 必须为 T 对象的 key 组成的联合类型的子类型。...{ [P in K]: T[P]; } 是对类型进行 重映射,这里的 P in K 表示遍历 K(K 是遍历类型),然后作为重映射类型的新 key,并且将 T[P] 作为值。...将key 替换为必选,我们还有 -readonly 的写法,将只读 key 转换为普通 key

3.1K10

关于PHP数组Key的强制类型转换

关于PHP数组Key的强制类型转换 PHP是弱类型语言,就像JavaScript一样,在定义变量时,不需要强制指定变量的类型。...同时,PHP又有着强大的数组功能,数组的Key即可以是普通的数字类型下标,也可以是字符串类型的Hash键值,那么,当一个数组的Key同时拥有字符串和数字时,会产生什么情况呢?...没错,PHP中的数组Key值只接受数字和字符串类型,当Key是字符串时,会强制转换为数字类型,遵守类型强制转换的规则。浮点数也是同样的道理,直接转换成了向下取整的整型。...在PHP官方文档中给出的Key值转换说明如下: 包含有合法整型值的字符串会被转换为整型。例如键名 "8" 实际会被储存为 8。但是 "08" 则不会强制转换,因为其不是一个合法的十进制数值。...github.com/zhangyue0503/dev-blog/blob/master/php/201910/source/%E5%85%B3%E4%BA%8EPHP%E6%95%B0%E7%BB%84Key

2.5K20
  • 处理TS类型声明文件,保留指定key类型声明

    我的原始需求是这样的,写了一个nodejs命令行工具,工具的功能是,拉取后端接口导出的 postman.json 接口内容,通过接口中的入参出参数据,生成入参出参的TS类型声明文件,达到在ts业务代码中可以校验接口入参和出参类型的目的...其他属性 } }; 上面的代码中,除了Data内的数据,其他的都是所有接口相同的属性内容,所以我需要处理生成的ts文件,只保留 Data 的类型描述。...的interface代码 * 使用babel的抽象语法树转换,处理,生成代码 * @param typeCode ts代码 * @param rootName 根类型名 * @param keyName...key的interface代码,现将代码转换成ast const ast = parser.parse(typeCode, { sourceType: 'module', plugins: ['typescript...'] }); let titleType = 'any'; // 从ast中找到指定key的接口,生成代码返回。

    11510

    ssh key类型这么多,要如何选择呢?

    用过ssh的朋友都知道,ssh key类型有很多种,比如dsa、rsa、 ecdsa、ed25519等,那这么多种类型,我们要如何选择呢? 今天看到一篇相关文章,写的挺好的,在这里分享下。...在具体看这篇文章之前,我们先说结论: 1. ssh key类型有四种,分别是dsa、rsa、 ecdsa、ed25519。 2....5. rsa是目前兼容性最好的,应用最广泛的key类型,在用ssh-keygen工具生成key的时候,默认使用的也是这种类型。...不过在生成key时,如果指定的key size太小的话,也是有安全问题的,推荐key size是3072或更大。...6. ed25519是目前最安全、加解密速度最快的key类型,由于其数学特性,它的key的长度比rsa小很多,优先推荐使用。它目前唯一的问题就是兼容性,即在旧版本的ssh工具集中可能无法使用。

    9.3K30

    TypeScript交叉类型&联合类型

    一、交叉类型(Intersection types)什么事交叉类型呢?简单来说就是通过&符号将多个类型进行合并成一个类型,然后用type来声明新生成的类型。...这里分两种情况,如果同名属性的类型相同则合并后还是原本类型,如果类型不同,则合并后类型为never2.基本数据类型交叉any和number交叉结果是any类型,any和boolean交叉结果是any类型...,如下图所示:3.2 键的类型是对象类型A、B、C三个类型都有相同的键inner,但是键的数据类型不同,分别是D、E、F,此时A&B&C会将inner键的类型进行合并,其实是D、E、F的交叉类型。...,当键的类型是不同的字面量类型,则交叉后类型为never类型。...二、联合类型(Union types)联合类型和交叉类型比较相似,联合类型通过|符号连接多个类型从而生成新的类型。它主要是取多个类型的交集,即多个类型共有的类型才是联合类型最终的类型

    66010

    java中map根据value找key_Java Map和Map类型,map通过value找key

    Map是Map的一个泛型形式,俩个之间实际上是一个东西,但是用法却有点不一样 1、Map:里面存放的是键值对集合,键值对的类型可以是任意封装类型 实例 Map map=new HashMap(); //...以下的俩种使用方式都是对的 map.put(“a”,1); map.put(11,”abc”); 2、Map:中只能存放指定类型key和指定类型的value如下 Map中只能存放String类型的键,...Object类型的值 实例 Mapmap=new HashMap(); //正确使用方式 map.put(“a”,1); //错误使用方式,会导致无法通过编译 map.put(11,”abc”); 补充说明...: 1、其实前面的Map相当于Map,这个是指装入的键是对象类型,装入的值是对象类型。...2、里面的内容代表范式,比如 Map就表示这个map的key是String,类型value是int类型,就是强制规定你map里面的类型,代码规范 遍历Map并通过value获取相应key值 Mapmap

    1.5K30

    TypeScript类型声明

    当我们使用TypeScript编写代码时,类型声明是非常重要的,它帮助我们定义变量、函数、类等的类型,从而提供更好的代码提示、类型检查和代码可读性。...以下是关于TypeScript类型声明的详细内容:基本类型声明在TypeScript中,我们可以使用以下关键字来声明基本类型:let num: number = 42;let str: string =...(Type Assertion)类型断言允许我们手动指定变量的类型,并告诉TypeScript编译器我们知道更多关于变量的类型信息。...: number; readonly id: number;}以上是关于TypeScript类型声明的一些重要内容。通过合理使用类型声明,我们可以增强代码的可读性、类型安全性和可维护性。...类型声明是TypeScript的核心特性之一,可以帮助我们构建更健壮的代码和应用程序。我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

    26520

    TypeScript 联合类型

    联合类型(Union Types)可以通过管道(|)将变量设置多种类型,赋值时可以根据设置的类型来赋值。注意:只能赋值指定的类型,如果赋值其它类型就会报错。...创建联合类型的语法格式如下:Type1|Type2|Type3 实例声明一个联合类型:TypeScriptvar val:string|number val = 12 console.log("数字为...console.log("数字为 " + val); val = "Runoob"; console.log("字符串为 " + val);输出结果为:数字为 12字符串为 Runoob如果赋值其它类型就会报错...:var val:string|number val = true 也可以将联合类型作为函数参数使用:TypeScriptfunction disp(name:string|string[]) { if...); disp(["Runoob", "Google", "Taobao", "Facebook"]);输出结果为:Runoob输出数组....RunoobGoogleTaobaoFacebook联合类型数组我们也可以将数组声明为联合类型

    8410

    TypeScript函数类型

    声明式类型函数 通过如下代码我们实现了一个返回值为number类型的方法,同时我们也对返回值和参数进行了约束 function funcType(name:string,age:number):number..."张三",18) 对方法进行添加默认值 function funcType2(name:string="张三",age:number=18):number{ return age; } 表达式类型函数...number):number } var funcType6:funcType5=function(name:string,age:number):number{ return age; } 联合类型重载...通过如下代码我们可以实现一个联合类型函数,当然这可以采用重载的方式 当我们的参数是number类型时我们的返回值是number类型,当我们的参数是string类型时我们的返回值是string类型,这一块具体在我们实际业务中可以根据实际需求进行相应修改

    78920

    TypeScript 类型系统

    总之,我们使用 Typescript 的主要目的仍然是要它的静态类型检查,帮助我们提供代码的扩展性和可维护性。因此 Typescript 需要维护一套完整的类型系统。 「类型系统包括 1....大家只要记住「Typescript 如果可以 100% 确定你的类型,并且这个类型要比你定义的或者 Typescript 自动推导的范围更小,那么就会发生类型收缩」就行了。...总结 本文主要讲了 Typescript类型系统。Typescript 和 JavaScript 的类型是很不一样的。...TypeScript 既会对变量存在与否进行检查,也会对变量类型进行兼容检查。因此 TypeScript 就需要定义一系列的类型,以及类型之间的兼容关系。...TypeScript 已经做到了足够智能了,以至于你不需要写类型,它也能猜出来,这就是类型推导和类型收缩。当然 TypeScript 也有一些功能,我们觉得应该有,并且也是可以做到的功能空缺。

    1.4K10

    TypeScript类型断言

    什么是类型断言 类型断言是可以手动指定一个值得类型 类型断言 let num3:number|string="10" num3=20 console.log(num3.length) 通过如上代码,当我们获取...length的时候会报错因为我们赋值为20所以不存在属性length,那么我们就可以采用类型断言去做处理 值 function getAssert(name:string|number) {...return (name).length; } 值as类型 function getAssert(name:string|number) { return (name as string...).length; } 因为只有在我们为string类型的时候才有length属性,所以这一块我们要采用类型断言的方式进行处理....通过如下代码我们可以发现会出现异常正如下方图片所示,因为他并非是强制类型转换,他只能断言联合类型中存在的类型.不存在的类型是不允许的. function getAssert(name:string|number

    74910
    领券