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

 更新时间:2022年08月16日 09:19:04   作者:smileForward  
这篇文章主要介绍了vue中使用ts配置的具体步骤,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

通过前端各个框架的发展,例如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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • 详解VUE 定义全局变量的几种实现方式

    详解VUE 定义全局变量的几种实现方式

    本篇文章主要介绍了VUE 全局变量的几种实现方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 关于element中对el-input 自定义验证规则

    关于element中对el-input 自定义验证规则

    这篇文章主要介绍了关于element中对el-input 自定义验证规则,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue 左滑删除功能的示例代码

    vue 左滑删除功能的示例代码

    这篇文章主要介绍了vue 左滑删除功能的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • vue中form表单禁用专用组件介绍

    vue中form表单禁用专用组件介绍

    这篇文章主要介绍了vue中form表单禁用专用组件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • vue源码中的检测方法的实现

    vue源码中的检测方法的实现

    这篇文章主要介绍了vue源码中的检测方法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • Vue2 Element Schema Form 配置式生成表单的实现

    Vue2 Element Schema Form 配置式生成表单的实现

    本文主要介绍了Vue2 Element Schema Form 配置式生成表单的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Vue数据与事件绑定以及Class和Style的绑定详细讲解

    Vue数据与事件绑定以及Class和Style的绑定详细讲解

    这篇文章主要介绍了Vue数据与事件绑定以及Class和Style的绑定,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-01-01
  • vue-cli脚手架-bulid下的配置文件

    vue-cli脚手架-bulid下的配置文件

    这篇文章主要介绍了vue-cli脚手架-bulid下的配置文件,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • vue时间线组件的使用方法

    vue时间线组件的使用方法

    这篇文章主要为大家详细介绍了vue时间线组件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • vue在手机中通过本机IP地址访问webApp的方法

    vue在手机中通过本机IP地址访问webApp的方法

    这篇文章主要介绍了vue在手机中通过本机IP地址访问webApp的方法,需要的朋友可以参考下
    2018-08-08

最新评论