vue中使用ts配置的具体步骤

目录

vue老项目引入TypeScripe

从零开始创建vue+TypeScripe项目

vue3加ts的配置与基本语法格式

下面是我写的一个小demo

通过前端各个框架的发展,例如vue3.0,react和angular等框架的源码都是用ts(TypeScripe)进行编写的,因此我感觉未来的中大型项目的发展趋势也离不开ts。

因此我根据一些入门教程利用vue结合ts编写了文档,适合入门配置vue+ts项目。

vue老项目引入TypeScripe npm install vue-class-component vue-property-decorator --save npm install ts-loader typescript tslint tslint-loader tslint-config-standard --save-dev

vue-class-component:扩展vue支持typescript,将原有的vue语法通过声明的方式来支持ts

vue-property-decorator:基于vue-class-component扩展更多装饰器

ts-loader:让webpack能够识别ts文件

tslint-loader:tslint用来约束文件编码,可装可不装,建议最好安装下,有利于代码规范

tslint-config-standard: tslint 配置 standard风格的约束,这个也是用来规范ts代码风格的

注:这种方式安装ts是为了将原有的vue项目中Js语法修改为Ts,详细步骤参考https://www.jb51.net/article/230703.htm此文中对于vue.config.js或者低版本的webpack.base.conf中配置支持ts语法展示不太完全,因此我修改如下:

// 对于文件插件配置,需要写在configureWebpack这个对象中。 module.exports = { configureWebpack: { resolve: { extensions: [".ts", ".tsx", ".js", ".json"] }, module: { rules: [ { test: /\.ts$/, exclude: /node_modules/, enforce: 'pre', loader: 'tslint-loader' }, { test: /\.tsx?$/, loader: 'ts-loader', exclude: /node_modules/, options: { appendTsSuffixTo: [/\.vue$/], } } ] } } } 从零开始创建vue+TypeScripe项目

这种方式比较简单,只要在用命令vue create app-name创建项目时选择自定义就可以创建,如下步骤:

第二步选中上面几种就行,在终端中利用空格键进行选中,选中之后回车,选择项含义如下:

(*) Babel //ES6转ES5 (*) TypeScript //使用ts ( ) Progressive Web App (PWA) Support //渐进式Web应用 (*) Router //路由 (*) Vuex //状态管理 (*) CSS Pre-processors //CSS预处理 (*) Linter / Formatter //规范类型 ( ) Unit Testing //测试 ( ) E2E Testing //测试

下一步的配置细节如下:

Use class-style component syntax? (Y/n) 是否使用class风格的组件语法 输入Y回车 Use Babel alongside TypeScript (required for modern mode, auto-detected polyfills, trans piling JSX)? (Y/n) 是否使用Babel和TypeScript(现代模式、自动检测多边形填充、trans所需(JSX) 输入Y回车 Use history mode for router? (Requires proper server setup for index fallback in product ion) (Y/n) 是否使用history路由模式 输入N回车 Pick a CSS pre-processor (PostCSS, Autoprefixer and CSS Modules are supported by default) 选择预处理器模式 我常选择Sass/SCSS (with node-sass) Pick a linter / formatter config: (Use arrow keys):选择语法检测规范 一般默认第一个ESLint with error prevention only, 但是使用ts可以选择TSLint Pick additional lint features: (Press to select, to toggle all, to invert selection) 选择保存时检查 / 提交时检查 一般开发时选择第一个保存时检查 Where do you prefer placing config for Babel, PostCSS, ESLint, etc.? (Use arrow keys) 选择配置信息存放位置,单独存放或者并入package.json 一般也是默认选择第一个,插件配置单独存放在一个文件 Save this as a preset for future projects? (y/N) 是否保存为预设,这样下次创建项目就不用重新选择 输入N回车

以上选项完成后项目就搭建成功了,项目目录如下:

vue.config.js这个文件需要自己创建,放在项目根目录下即可

vue3加ts的配置与基本语法格式

 

class-style 是vue中使用了ts的class-style的风格,也可以不加

Babel alongside TypeScript是使用Babel做转义, 与TypeScript一起用于自动检测

history是路由是否为哈希模式,这里选否,哈希模式路径要加#

  

现在是选择代码风格检查和格式化的配置

ESLint with error prevention only 指仅用于错误预防

ESLint + Airbnb config 指ESLint 和Airbnb代码规范

ESLint + Standard config 指ESLint 和Standard代码规范

ESLint + Prettier 指ESLint 和Prettier代码规范

这里先选默认ESLint with error prevention only

1是严格模式,代码格式不规范也会报错

2是除了语法错误外不会提示 

询问项目的配置文件存放在哪儿(1是独立文件,2是在package.json)这里选择独立的文件,选择2在后续配置postcs适配时存在问题。 

 这一步是, 是否保存,选是的话会记住这次的配置

 接下来 npm run serve 启动项目就ok了

下面是我写的一个小demo

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易知道(ezd.cc)。 

推荐阅读

    atsl电脑板故障|atsl车身控制模块故障

    atsl电脑板故障|atsl车身控制模块故障,atsl电脑板故障,1、2机械故障通过维修更换内部机械零件,可以解决机械故障。2、电路的故障有保险丝烧

    vue项目一些常见问题

    vue项目一些常见问题,组件,样式,**样式污染问题**同样的样式不需要在每个组件都复制组件内单独的样式加外层class包裹。加scope。否则只是

    01-Vue项目实战-网易云音乐-准备工作

    01-Vue项目实战-网易云音乐-准备工作,网易,项目,前言在接下来的一段时间,我会仿照网易云音乐,利用Vue开发一个移动端的网易云音乐项目。在做

    三星GTS8600|三星gts8600拆机

    三星GTS8600|三星gts8600拆机,,三星GTS8600是入门级显卡。8600gts是英伟达早期推出的办公显卡,不是游戏显卡,显存只有256mb不能玩任何游戏。

    01- 第一天 spring boot2.3.1 +vue3.0 后台管理系统的研发

    01- 第一天 spring boot2.3.1 +vue3.0 后台管理系统的研发,自己的,后台,后台框架一直想开发一套完全属于自己的后台,但是18年的时候,曾经答

    3900元TsinghuaTongfang真爱u8880桌面

    3900元TsinghuaTongfang真爱u8880桌面,,我们仍在为您收集个性化的替代家庭桌面。我们感到不安。品牌外观设计缺乏创新,严重制约了品牌机器

    Bootstrap的js插件之模态框|modal

    Bootstrap的js插件之模态框|modal,模态,饭盒,.modal——指明div元素包裹模态框;.fade——给模态框添加淡入淡出效果;.modal-dialog——包裹

    Vue项目中 App.vue文件

    Vue项目中 App.vue文件,文件,内容, 在App.vue文件中,定义了一个id为app的div,在这个div板块中放置Helloworld组件,文件内容如下图所示:在

    前端初学者应该使用bootstrap吗

    前端初学者应该使用bootstrap吗,方法,的是,前端初学者应该使用bootstrap吗没有啊,前端范围还是很大的,bootstrap只是某一套样式框架.。你可