Vue2 Vue-cli中使用Typescript的配置详解


Posted in Javascript onJuly 24, 2017

前言

因为最近公司的团队热衷于vue框架,新项目想着练练typescript,于是开始了vue+ts的踩坑之路...本文意在为和我有一样想法的伙伴们省去踩坑的时间,下面话不多说了,来一起看看关于Vue2 Vue-cli中利用Typescript需要的配置是什么吧。

一、初步配置

首先安装官方插件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
 }
}

二、实战!

配好配置只是第一步,在项目里跑起来才是王道。

在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,不然一些ts语法不会被识别,像public修饰符之类的,因为ts还不是很熟练就没想着配,有兴趣的朋友可以试试。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
js类型检查实现代码
Oct 29 Javascript
初学js插入节点appendChild insertBefore使用方法
Jul 04 Javascript
JavaScript语言对Unicode字符集的支持详解
Dec 30 Javascript
JavaScript代码判断点击第几个按钮
Dec 13 Javascript
Vue.js实现拖放效果的实例
Sep 30 Javascript
详解Vue 非父子组件通信方法(非Vuex)
May 24 Javascript
Node.js中环境变量process.env的一些事详解
Oct 26 Javascript
JavaScript定义及输出螺旋矩阵的方法详解
Dec 01 Javascript
Angular中管道操作符(|)的使用方法
Dec 15 Javascript
Nuxt.js踩坑总结分享
Jan 18 Javascript
Redux实现组合计数器的示例代码
Jul 04 Javascript
React路由鉴权的实现方法
Sep 05 Javascript
mui开发中获取单选按钮、复选框的值(实例讲解)
Jul 24 #Javascript
JavaScript对JSON数据进行排序和搜索
Jul 24 #Javascript
Angular中ng-repeat与ul li的多层嵌套重复问题
Jul 24 #Javascript
深入理解React Native原生模块与JS模块通信的几种方式
Jul 24 #Javascript
浅析JavaScript中的平稳退化(graceful degradation)
Jul 24 #Javascript
vue.js移动端app实战1:初始配置详解
Jul 24 #Javascript
React 子组件向父组件传值的方法
Jul 24 #Javascript
You might like
如何使用动态共享对象的模式来安装PHP
2006/10/09 PHP
typecho插件编写教程(二):写一个新插件
2015/05/28 PHP
php5.2的curl-bug 服务器被php进程卡死问题排查
2016/09/19 PHP
PHP防止图片盗用(盗链)的方法小结
2016/11/11 PHP
jValidate 基于jQuery的表单验证插件
2009/12/12 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
2010/09/28 Javascript
javascript相等运算符与等同运算符详细介绍
2013/11/09 Javascript
jQuery+HTML5实现手机摇一摇换衣特效
2015/06/05 Javascript
Jquery日历插件制作简单日历
2015/10/28 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
2016/01/27 Javascript
酷! 不同风格页面布局幻灯片特效js实现
2021/02/19 Javascript
js 获取今天以及过去日期
2017/04/11 Javascript
JavaScript实现打印星型金字塔功能实例分析
2017/09/27 Javascript
微信小程序使用radio显示单选项功能【附源码下载】
2017/12/11 Javascript
vue动态注册组件实例代码详解
2019/05/30 Javascript
Layer组件多个iframe弹出层打开与关闭及参数传递的方法
2019/09/25 Javascript
JavaScript图片旋转效果实现方法详解
2020/06/28 Javascript
js+canvas实现刮刮奖功能
2020/09/13 Javascript
对于Python的Django框架部署的一些建议
2015/04/09 Python
MySQL最常见的操作语句小结
2015/05/07 Python
深入理解python try异常处理机制
2016/06/01 Python
Django中的文件的上传的几种方式
2018/07/23 Python
python组合无重复三位数的实例
2018/11/13 Python
python判断计算机是否有网络连接的实例
2018/12/15 Python
利用python在excel里面直接使用sql函数的方法
2019/02/08 Python
Python实现定时自动关闭的tkinter窗口方法
2019/02/16 Python
pyinstaller打包单个exe后无法执行错误的解决方法
2019/06/21 Python
matplotlib.pyplot画图并导出保存的实例
2019/12/07 Python
基于Python实现视频的人脸融合功能
2020/06/12 Python
selenium与xpath之获取指定位置的元素的实现
2021/01/26 Python
webapp字号大小跟随系统字号大小缩放的示例代码
2018/12/26 HTML / CSS
财务务虚会发言材料
2014/10/20 职场文书
校本课程教学计划
2015/01/19 职场文书
教师节联欢会主持词
2015/07/04 职场文书
详解JavaScript中Arguments对象用途
2021/08/30 Javascript
Nginx 反向代理解决跨域问题多种情况分析
2022/01/18 Servers