摘要:这里拿之前写的的代码当个栗子元数据写在配置里,像名字,用到的组件啥的,然后说下之前里用到的各个实例属性方法在这里怎么用这个是最常用的,像上面的这里一共声明了个,注意这里声明的变量一定要赋一个值,没有就不能是,不然这个数据就不是响应的。
公司的团队最近热衷于vue框架,新项目想着练练typescript,于是开始了vue+ts的踩坑之路...
本文意在为和我有一样想法的伙伴们省去踩坑的时间
1.初步配置
首先安装官方插件vue-class-component,vue-property-decorator,配置webpack。
webpack配置如下:
修改入口文件
</>复制代码
entry: {
app: "./src/main.ts"
}
resolve部分:
</>复制代码
extensions: [".js", ".vue", ".json", ".ts", ".tsx"]
配置loader
</>复制代码
{
test: /.tsx?$/,
loader: "ts-loader",
exclude: /node_modules/,
options: {
appendTsSuffixTo: [/.vue$/],
}
}
配置tsconfig.json
</>复制代码
{
"include": [
"src/**/*"
],
"exclude": [
"node_modules"
],
"compilerOptions": {
"allowSyntheticDefaultImports": true,
"experimentalDecorators": true,
"allowJs": true,
"module": "es2015",
"target": "es5",
"moduleResolution": "node",
"experimentalDecorators": true,
"isolatedModules": true,
"lib": [
"dom",
"es5",
"es2015.promise"
],
"sourceMap": true,
"pretty": true
}
}
2.实战!
配好配置只是第一步,在项目里跑起来才是王道。
在vue文件的script标签里添加lang="ts"
因为ts-loader不像配过loader的webpack一样知道vue,html等文件是什么东西,你跑起来后会报模块无法解析的错误,所以还需要配置.d.ts声明文件
vue的如下配置
</>复制代码
declare module "*.vue" {
import Vue from "vue";
export default Vue;
}
你也可以为其它的非js模块配置.d.ts文件
如html(告诉ts-loader把html理解成字符串)
</>复制代码
declare module "*.html" {
let template: string;
export default template;
}
配置好之后ts就能理解这些模块了
从vue-property-decorator引入需要用到的模块
(一般只用到Component, Vue, Watch, Prop这四个,其它3个没用到也没研究,知道的大佬可以解释下。)
import { Component, Vue, Watch } from "vue-property-decorator"
这里拿之前写的sidbar的代码当个栗子:
</>复制代码
class HoverTopElem {
leaveTop: number = -200
top: number = null
height: number = null
show(e) {
this.top = e.target.getBoundingClientRect().top
this.height = e.target.clientHeight
}
hidden() {
this.top = this.leaveTop
}
}
@Component({
name: "sidebar",
template: template,
components: {
sidebarItem
}
})
export default class Sidebar extends Vue {
SidebarMenu: any = SidebarMenu
hoverTopElem: HoverTopElem = new HoverTopElem()
activeListItemName: string = null
activeRouteItemRoute: string = null
get _activeRouteItemRoute(): string {
return this.$route.path
}
@Watch("_activeRouteItemRoute", { immediate: true })
onRouteChanged(val: any) {
this.activeRouteItemRoute = val
}
changeList(param) {
this.activeListItemName = param
}
changeRoute(param) {
this.activeRouteItemRoute = param
}
}
元数据写在@Component配置里,像名字,用到的组件啥的,然后说下之前vue里用到的各个实例属性方法在这里怎么用:
data: 这个是最常用的,像上面的SidebarMenu(这里一共声明了4个),注意这里声明的
变量一定要赋一个值,没有就null,不能是undefined,不然这个数据就不是响应的。因此HoverTopElem类里的属性也是要有初始值,不然这些属性也不是响应的
computed: 这里就是get函数,注意tsconfig.jsonp不配置"target": "es5"这里会报错
prop: vue-property-decorator里面有Prop模块,也可以在元数据声明这个prop,然后在类里声明一下这个变量就可以了,个人推荐第一种
watch: vue-property-decorator里的Watch模块
methods: 方法像data一样直接写在类里就可以了(注意不要和周期钩子同名)
各种生命周期钩子: 直接写就行
路由钩子见vue-class-component文档
至此,基本就可以像原来一样写vue组件了。
当然如果要想和原来一样写ts,还需要配置tslint,vue-cli自带的eslint不识别一些ts语法,像public修饰符之类的,导致编译失败,因为ts还不是很熟练就没想着配,有兴趣的朋友可以试试。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/84236.html
摘要:哪吒别人的看法都是狗屁,你是谁只有你自己说了才算,这是爹教我的道理。哪吒去他个鸟命我命由我,不由天是魔是仙,我自己决定哪吒白白搭上一条人命,你傻不傻敖丙不傻谁和你做朋友太乙真人人是否能够改变命运,我不晓得。我只晓得,不认命是哪吒的命。 showImg(https://segmentfault.com/img/bVbwiGL?w=900&h=378); 出处 查看github最新的Vue...
摘要:引入全面指南系列目录引入全面指南引入全面指南篇写在前面写这篇文章时的我,使用经验三个多月,完全空白,花了大概三个晚上把手头项目迁移至,因此这篇文章更像个入门指引。见文章引入全面指南篇完整代码见库,分支为整合示例,分支为不含的基础示例。 Vue2.5+ Typescript 引入全面指南 系列目录: Vue2.5+ Typescript 引入全面指南 Vue2.5+ Typescrip...
摘要:五六月份推荐集合查看最新的请点击集前端最近很火的框架资源定时更新,欢迎一下。苏幕遮燎沈香宋周邦彦燎沈香,消溽暑。鸟雀呼晴,侵晓窥檐语。叶上初阳乾宿雨,水面清圆,一一风荷举。家住吴门,久作长安旅。五月渔郎相忆否。小楫轻舟,梦入芙蓉浦。 五、六月份推荐集合 查看github最新的Vue weekly;请::点击::集web前端最近很火的vue2框架资源;定时更新,欢迎 Star 一下。 苏...
摘要:五六月份推荐集合查看最新的请点击集前端最近很火的框架资源定时更新,欢迎一下。苏幕遮燎沈香宋周邦彦燎沈香,消溽暑。鸟雀呼晴,侵晓窥檐语。叶上初阳乾宿雨,水面清圆,一一风荷举。家住吴门,久作长安旅。五月渔郎相忆否。小楫轻舟,梦入芙蓉浦。 五、六月份推荐集合 查看github最新的Vue weekly;请::点击::集web前端最近很火的vue2框架资源;定时更新,欢迎 Star 一下。 苏...
阅读 1637·2021-11-17 09:33
阅读 3200·2021-10-13 09:39
阅读 2874·2021-10-09 10:01
阅读 2602·2021-09-29 09:35
阅读 4144·2021-09-26 10:01
阅读 3662·2019-08-26 18:37
阅读 3317·2019-08-26 13:46
阅读 2038·2019-08-26 13:39
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要