vue.js使用typescript踩坑记

最近在把https://github.com/renrenio/renren-fast-vue这个项目转为typescript,在此记录一下遇到的小坑

 

name坑:属性该怎么给?

声明文件坑:如何解决不认识的对象\方法?

 

name坑

原代码如下图

 


 转TS后代码如下:

报错如下:

 [Vue warn]: Unknown custom element: - did you register the component correctly? For recursive components, make sure to provide the "name" option.

 

很明显,提示没有提供name属性,但是代码里面明显是有写name='sub-menu'的,查了一下vue的api,发现这个name并不是一个普通的属性,作为特殊的选项,基本是放在@Component这个装饰器中,查看文档后添加name,正常运行

vue.js使用typescript踩坑记_第1张图片

 

 

echarts部分方法不认识

其实这类问题在转ts的时候经常会遇到,本例中,我在项目中安装echarts的types之后,仍然有一些方法不认识,ts在编译时报错不能继续,这时候需要运用typescript的声明合并这个功能来解决。

问题如下图,vscode提示 RadialGradient找不到

vue.js使用typescript踩坑记_第2张图片

看了一下在graphic的定义

vue.js使用typescript踩坑记_第3张图片

显然是没有RadialGradient的定义,我们不可能直接去修改引用来的index.d.ts,解决办法是在项目目录中再新建一个xxx.d.ts文件,添加申明去扩展Graphic这个接口

vue.js使用typescript踩坑记_第4张图片

原谅我偷了懒,直接用any,不想去细究这个RadialGradient从哪来的,现在ts就不会再报错了。关于声明文件的写法,一定要认真看ts的文档。

 

转载于:https://www.cnblogs.com/zdkjob/p/10572150.html

你可能感兴趣的:(vue.js使用typescript踩坑记)