vue接入ts基本方法

目录
  • 一、依赖记
  • 二、配置记
  • 三、修改记
    • 1.将必要文件的.js替换为.ts
    • 2.vue文件修改
  • 四、填坑记

下面将以项目搭建的方式完成改文章叙述:

项目基础架构是通过cli搭建的,主要是vue(2.5.16)+ webpack(3.6.0)+ element-ui(2.8.2),整体项目还简单用了vuex,eslint等。

一、依赖记

项目从基础js改为ts,因为是初次尝试,本着最小依赖、最小改动原则,只引入了一些基础依赖:

  • typescript:#3.1.6 -- 接入ts的基础依赖,版本需要根据项目相关版本进行修改
  • ts-loader:#3.5.0 -- 同样是基础依赖
  • ts-lint tslint-config-standard tslint-loader -- 这三个是将原来的eslint校验替换掉,没仔细研究过,应该是可以处理一些引入了ts之后eslint导致的莫名其妙的校验问题。

二、配置记

webpack.base.config.js修改:

入口文件将原来的.js改为.ts

entry: {
    app: ['babel-polyfill', './src/main.ts']
 },

resolve.extensions增加ts:

extensions: ['.tsx', '.ts', '.js', '.vue', '.json'],

rules增加对ts的解析:

{
    test: /\.(ts|tsx)?$/,
    loader: 'ts-loader',
    exclude: /node_modules/,
    options: {
      appendTsxSuffixTo: [/\.vue$/],  // ts不知道如何处理.vue结尾文件,需加此配置
      happyPackMode: true  // 开启多线程,加快编译
    }
 }

eslint替换为tslint:

{
    test: /\.ts$/,
    loader: 'tslint-loader',
    exclude: /node_modules/,
    enforce: 'pre'
}

同时在vue-loader.conf.js里增加配置,在根目录下增加tslint.json配置文件:

// vue-loader.conf.js
const mergeVue = require('webpack-merge')

loaders: mergeVue(utils.cssLoaders({
    sourceMap: sourceMapEnabled,
    extract: isProduction
}), {
    ts: ['ts-loader', 'tslint-loader']   // 新增
}),

// tslint.json
{
    "extends": "tslint-config-standard",
    "globals": {
      "require": true
    },
    "rules": {
      "no-consecutive-blank-lines": false
    }
}

另外还有其他一些基础的修改,比如ts会校验不同文件间的重名,并给出错误提示。这点当然可以通过配置去处理,但是个人觉得这个提示可以保留,只需要修改对应的变量名就可以了。
新增配置文件tsconfig.json(个别配置字段会在后面填坑说明)

{
  "compilerOptions": {
    "target": "es5",
    "strict": true,
    "module": "es2015",
    "moduleResolution": "node",
    "baseUrl": ".",
    "paths": {
      "@/*": ["src/*"]
    },
    "types": [
      "node"
    ],
    "noImplicitAny": false,
    "allowSyntheticDefaultImports": true
  }
}

src目录下增加 vue.d.ts 文件:

此文件主要是告诉ts,.vue结尾的文件交给vue去处理。但是这样会造成一个父子组件引用问题,同样后边填坑单说。

declare module '*.vue' {
    import Vue from 'vue'
    export default Vue
}

三、修改记

1.将必要文件的.js替换为.ts

这里说必要的js结尾文件,我处理的主要是逻辑相关的文件,对于一些config类型的文件并没有修改,依然保留了js结尾,目的是最小改动原则,避免一些难处理的问题。

2.vue文件修改

针对vue文件:

  • 需要在script标签上增加 lang='ts'
  • 同时需要用vue.extend定义组件
  • 如果有引用其他组件,未引入ts时候可以省略.vue后缀,但是引入ts之后,引入组建的时候一定要加上.vue后缀
<script lang="ts">
import Vue from 'vue'
import Table from '@/components/table/index.vue'

export default Vue.extend({
    data(){
        return {
            name: ''
        }
    }
})

经过以上三步基础的修改,如果你的项目非常简单,简单到就是个测试架子,那就可以愉快地npm start了,没有太大问题。但是如果是原有项目,去start的时候,会爆出很多警告问题,当然如果是基础的ts校验问题,我们可以去直接修改文件或者配置即可。

忽略ts格式校验,我们可以看到原有项目里增加ts语法后(或者未增加ts语法)会出现另外一些问题,可能问题并不会影响到程序的编译运行,但是在编辑器里会飘红~ 接下来就简单说下所填的几个坑。

四、填坑记

Cannot find name ‘require‘. Do you need to install type definitions for node? 当我们用require引入某些文件时,可能会出现这个错误提示,这种问题基本就是需要安装对应的@type依赖,针对此问题:

安装:npm i --save-dev @types/node,在tsconfig.json里增加 "types": ["node"],如果还是有错误提示,可以添加 declare var require: any。

类似的问题还有引入lodash、qs等,需要安装对应的@type/xx。如果使用了vue-cookie,需要安装对应的ts版本 vue-cookies-ts同时对应的方法需要做修改,详见文档 vue-cookies-ts 。

Cannot find module ‘XXX‘ or its corresponding type declarations.Vetur 这种错误出现场景是,我们按照基础内容配置好之后,通过import引入某个ts文件的时候出现的。这个问题其实挺诡异的,如果加上.ts后缀,会提示不需要加,去掉后缀之后就报找不到模块。

这个问题解决办法一种就是看有没有配置alias,同时需要在tsconfig.json里增加 "paths": {"@/*": ["src/*"]}。配置之后如果还不生效,基本方法二就能解决了,方法二就是把项目放在第一个,就是用vscode直接打开一个项目,而不是打开某个文件夹下有很多项目的情况。这个问题应该是vetur插件导致的。当然还有第三种方法就是添加单独的vetur配置,这个没有去研究,有时间的小伙伴可以考虑下。

Property ‘$http‘ does not exist on type ‘xxx‘ 通常vue开发我们网络请求会使用axios封装一个统一的方法,在main.ts里引入绑定:

import httpRequest from '@/utils/httpRequest'
Vue.prototype.$http = httpRequest

// 方法的使用
this.$http()

在使用this(Vue)去使用的时候会出现报错提示,考虑原因是因为我们上边配置了vue.d.ts,.vue结尾的文件都当做vue去处理,而vue是没有$http方法的,最简单的办法就是直接上any了,(this as any).$http ,但是对于成型项目来说这么写改动内容太多了。可以采用如下方法(同样处理了$store的使用问题):

在src下新建一个vue-shim.d.ts添加下面配置:

import { Store } from 'vuex';
declare module 'vue/types/vue' {
    interface Vue {
        '$stroe': Store,
        '$http': any
    }
}

Property 'resetFields' does not exist on type 'Vue'

如果使用了element表单相关方法,可能会涉及到表单清空、重置之类的方法调用,通常做法可以给form一个ref,然后通过 this.$refs['xxx'].resetFields()调用。但是加入ts之后会提示错误,原因同样是这里的this被指向了vue,不存在相关方法。

解决方法使用类型断言,将ref断言成element相关内容:

import { Form as EleForm } from 'element-ui'
// 方法内部
const ref = this.$refs['searchForm'] as EleForm
ref.resetFields()

还有一种情况,就是父子组件间,在父组件内部去使用子组件的方法,同样是使用ref去调用,也会出现上边的错误提示。这个问题开始考虑是用类似的断言,把ref断言成子组件,但是方法不通,通过网上搜索也没找到合适的方法,大部分方法都是直接断言成了any,即(this.$refs['xxx'] as any).clearList() 。这么断言,问题是可以解决的,但是希望能找到更合适的方法,

到此这篇关于vue接入ts基本方法的文章就介绍到这了,更多相关vue接入ts内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Vue3+Vite+TS实现二次封装element-plus业务组件sfasga

    目录 1.结构字符串 2.返回tuple元组 3.访问Dict字典 4.运用库 5.在列表中切片/步进 6.用 ranges 1.结构字符串 你会经常需求打印字符串.要是有很多变量,防止下面这样: name = "Raymond" age = 22 born_in = "Oakland, CA" string = "Hello my name is " + name + "and I'm " + str(age) + &quo

  • vue项目中使用ts(typescript)入门教程

    目录 1.引入Typescript 2.配置文件webpack配置 3.让项目识别.ts 4.vue组件的编写 data()中定义数据 props传值 完整代码案例 最近项目需要将原vue项目结合ts的使用进行改造,这个后面应该是中大型项目的发展趋势,看到一篇不错的入门教程,结合它并进行了一点拓展记录之.本文从安装到vue组件编写进行了说明,适合入门. 1.引入Typescript npm install vue-class-component vue-property-decorator --

  • vue接入ts基本方法

    目录 一.依赖记 二.配置记 三.修改记 1.将必要文件的.js替换为.ts 2.vue文件修改 四.填坑记 下面将以项目搭建的方式完成改文章叙述: 项目基础架构是通过cli搭建的,主要是vue(2.5.16)+ webpack(3.6.0)+ element-ui(2.8.2),整体项目还简单用了vuex,eslint等. 一.依赖记 项目从基础js改为ts,因为是初次尝试,本着最小依赖.最小改动原则,只引入了一些基础依赖: typescript:#3.1.6 -- 接入ts的基础依赖,版本需

  • Vue接入高德地图的完整实例

    目录 前言 参考资料 Vue接入高德地图 引用 使用 实现点击按钮缩放功能 地图放大 地图缩小 测量距离 测量面积 行政区划查询渲染 关键字搜索 鼠标绘制区域 总结 前言 Vue 使用高德地图,实现缩放,鼠标绘制,测距.测面积.行政区域范围绘制.关键词查询等操作. 参考资料 高德地图API官网:https://lbs.amap.com/ 高德地图2.0参考手册:https://lbs.amap.com/api/jsapi-v2/documentation#pixel 高德地图2.0示例代码:ht

  • VUE接入腾讯验证码功能(滑块验证)备忘

    最近在用VUE做个简单的用户系统,登录注册需要验证码,想找个那种拖动的,找geetest居然已经不面向小客户了(或者说只有收费套餐). 腾讯防水墙的验证码免费使用,有2000/小时的免费额度,对于小网站完全足够了,阿里应该也有,我看discuz有插件直接能用,但没找到入口 腾讯的在这,和腾讯云无关:https://007.qq.com/captcha/#/  申请api很简单,QQ登录,创建应用,ID和secretkey就出来了,直接在文档里展示,赞一个. vue有人做了封装了geetest+腾

  • vue接入腾讯防水墙代码

    vue接入腾讯防水墙代码,具体代码如下所示: 开始创建代码: 登陆调用方法代码 总结 以上所述是小编给大家介绍的vue接入腾讯防水墙代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的.在此也非常感谢大家对我们网站的支持! 如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

  • Vue-Element-Admin前端接入SSO的方法步骤

    目录 概要 SSO 前端页面 1. config.js文件 2. SSO.js文件 3. 修改permission.js文件 4. 修改vue.config.js文件 5. 运行 概要 相信很多像我一样初入门前端的时候,都是基于某个模板来学. vue-element-admin 或者 vue-element-template是一个很好的模板.而在后期,一般公司都会要求接入SSO, 作者觉得这个太简单了,都是后台的工作,前端 只需判断后台返回的token或者其他信息就可以,所以在相关文档中也没有太

  • vue接入高德地图绘制扇形效果的案例详解

    目录 vue接入高德地图绘制扇形 需求 预想效果 代码实现 绘制基站第一步 绘制基站第二步 - 计算扇形形状 计算扇形坐标 扇区点击事件 原点点击事件 vue接入高德地图绘制扇形 为什么又写这一篇呢,主要是因为这个功能高德不支持,只能自己实现,但是呢,我估计很多人会用到这玩意儿.所以说呢,就简单的实现一下,如果有需要的话直接超过去就行,之前写过天地图绘制扇形区域的,如果使用天地图的话可以翻一下我之前的博客,百度地图和这个方法类似,可能就是使用的类不同,这样的话只要原理流程理解的差不多,直接把各个

  • vue分类筛选filter方法简单实例

    本文实例为大家分享了vue分类筛选filter方法的具体代码,供大家参考,具体内容如下 <html> <head> <meta charset="utf-8"> <title>filter</title> </head> <body> <div id="app"> <ul> <li v-for="item in filterlist"

  • Vue的MVVM实现方法

    本文介绍了Vue的MVVM实现方法,分享给大家,具体如下: 1. Object.defineProperty() 定义属性 用意:给一个对象定义属性,那个属性原来是不存在的.这是一个初衷,属性是不存在的,需要额外添加. ①.使用说明 Object.defineProperty(obj,props) 第一个参数是将被添加或者修改的属性的对象 第二个参数是一个对象,表示将要添加的一个或多个键值对一直要添加属性的具体配置 { ​ '属性名':{value:'...',writable:true}, ​

  • vue跨域解决方法

    vue项目中,前端与后台进行数据请求或者提交的时候,如果后台没有设置跨域,前端本地调试代码的时候就会报"No 'Access-Control-Allow-Origin' header is present on the requested resource." 这种跨域错误. 要想本地正常的调试,解决的办法有三个: 一.后台更改header header('Access-Control-Allow-Origin:*');//允许所有来源访问 header('Access-Control

  • 通过命令行生成vue项目框架的方法

    本文介绍了通过命令行生成vue项目框架的方法,现在分享给大家 -- 安装nodejs 用命令行生成vue项目框架需要npm包管理器来安装,而npm又是在安装nodejs的时候同时安装的, 所以首先要安装nodejs,学习vue有必要了解下nodejs和npm的基本知识: nodejs安装: http://www.jb51.net/article/113457.htm npm 介绍: http://www.jb51.net/article/87893.htm -- 安装命令行工具 npm inst

随机推荐