首页IT科技ts报错应有一个参数但获得两个(TS报错:Parameter xxx implicitly has an any type的解决方式)

ts报错应有一个参数但获得两个(TS报错:Parameter xxx implicitly has an any type的解决方式)

时间2025-06-19 03:50:03分类IT科技浏览3966
导读:Parameter ‘xxx’ implicitly has an ‘any’ type的解决...

Parameter ‘xxx’ implicitly has an ‘any’ type的解决

这句话翻译过来就是参数暗指是any类型

在TS中等同于以下代码:

const f = (param: any) => { //无意义代码 console.log(param); };

产生的原因:

在TS中如果没有定义参数类型的话就会报这个信息             。

这是属于是JS的编码风格             ,但在TS当中                   ,你需要给它赋上类型                   。

实例:

//Parameter param implicitly has an any type.ts(7006) const f = (param) => { //param类型可能为any console.log(param); }; *******解决方式(参考)******* //假如param为字符串类型      ,可以这样做 /** const f=(param: string)=>{ console.log(param); } */ //假如param为数字类型       ,可以这样做 /** const f=(param: number)=>{ let sum=param+100; //sum没有声明类型                   ,是因为TS的自动类型推断            ,param为数字类型       ,加上100,那么TS就会推出sum为数字类型      。 console.log(sum); } */ //假如param为XXX数组类型                    ,可以这样做 /** const f=(param: XXX[])=>{ param.forEach((e: XXX)=>{ console.log(e) }) } */

其它解决(非常不提倡):

在tsconfig.json当中使用 “noImplicitAny             ”: false 或者 “strict                   ”: false 或者使用tsc命令带上以上两个参数

使用这个意味着将TS的类型检测给屏蔽了            ,也就是说,你写的语法还是JS语法                    ,与TS没什么关系(无意义的行为)

参考文档中这两个字段的解释:

–noImplicitAny:在表达式和声明上有隐含的 any类型时报错       。

–strict:启用所有严格类型检查选项                   。

TS是不鼓励使用any类型(除特殊情况)                   ,如果所有的变量,参数等都为any             ,那TS基本类型检查功能就等于没有使用到

TypeScript的核心原则之一是对值所具有的结构进行类型检查            。

实例:

//原生js语法 function f(param){ let stringList=param.split("-"); console.log(stringList) } f("g-s-e-g-s"); //正常调用 f(23324); //非正常调用 //js中这两个都是没有错                   ,但在运行时      ,就会error //然而在TS中这会被检测出来             ,所以定义any类型和使用原生js的语法变化不大

如何来解决(想法):

根据参数类型对其进行特定的声明       。

实例( 仅参考 ):

param是字符串数组类型:

const displayList = (param: string[]) => { param.forEach((element: string) => { console.log(element); }); }; displayList([Hello, World, !]); /** * 输出: * Hello * World * ! */

param是自定义personType的类型:

type personType = { //自定义类型 name: string; age: number; gender: string; }; const displayPersonName = (param: personType) => { console.log(姓名:, param.name); }; //参数 let person_1: personType = { name: personName01, age: 21, gender: , }; let person_2: personType = { name: personName02, age: 22, gender: , }; //调用 displayPersonName(person_1); displayPersonName(person_2); /** * 输出: * 姓名: personName01 * 姓名: personName02 */

总结

到此这篇关于TS报错:Parameter xxx implicitly has an any type解决的文章就介绍到这了,更多相关Parameter xxx implicitly has an any type内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!

声明:本站所有文章                   ,如无特殊说明或标注      ,均为本站原创发布                    。任何个人或组织       ,在未征得本站同意时                   ,禁止复制             、盗用                   、采集      、发布本站内容到任何网站       、书籍等各类媒体平台            。如若本站内容侵犯了原著者的合法权益            ,可联系我们进行处理。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
python 发送(Python中包如何发布?) wordpress批量上传插件(WordPress定时删除文章:简化网站管理的必备技巧)