通过vue-cli命令行安装vue项目,注意不要eslint

  1. 安装依赖

    cnpm install typescript --save-dev
    cnpm install ts-loader --save-dev
  2. 在vue配置文件 webpack.base.conf.js 中做修改

    在rules中的js配置对象下面添加
    {
    test: /\.ts$/, 解析在vue文件中的ts脚本
    loader: 'ts-loader', 使用 ts-loader 解析
    exclude: /node_modules/, 无视node_modules
    options: {
    appendTsSuffixTo: [/\.vue$/], 设置vue文件可以使用ts
    }
    }
    然后将entry改成如下
    entry: {
    app: './src/main.ts'
    }
    再把你的入口文件main.js文件后缀名改成ts
    其余的配置不要动
  3. 新建指向文件

    在项目的src跟目录中创建一个后缀为.d.ts的文件,此文件名称随意,我使用index
    index.d.ts文件
    写如下代码,表示声明一个模块,应用于所有的vue组件的import语句中
    declare module "*.vue" {
    import Vue from "vue";
    export default Vue;
    }
    这个文件一旦声明,ts-loader就会找到Vue
  4. 新建typescript配置文件

    在项目根目录创建
    tsconfig.json文件
    添加如下配置
    {
    "compilerOptions": {
    "module": "es2015", 指定模块是es2015的
    "moduleResolution": "node", 指定路径解析方式用node
    "target": "es5", 指定编译后的js使用es5版本
    "allowSyntheticDefaultImports": true, 允许使用 import Vue from 'vue' 这类语法
    "lib": [
    "dom",
    "es5",
    "es2015.promise"
    ]
    },
    "include": [
    "src/**/*"
    ],
    "exclude": [
    "node_modules",
    "**/*.spec.ts"
    ]
    }
  5. 基本使用

    <script lang="ts">
    export default {
    name: 'HelloWorld',
    data (): object {
    return {
    msg: 'Welcome to Your Vue.js App'
    }
    }
    }
    </script>
  6. vue内置类型使用

    vue其实在你安装之后,默认已经帮你弄好了.d.ts文件,关于vue本身的验证他们都做好了,我们直接拿来用就可以了
    <script lang="ts">
    import Vue, { ComponentOptions } from 'vue';
    interface HelloWorld extends Vue {
    msg: string
    }
    export default {
    name: 'HelloWorld',
    data (): object {
    return {
    msg: 'Hello World!'
    }
    }
    } as ComponentOptions<HelloWorld>
    </script>
    ComponentOptions这个东西是用来验证vue的内置的一些属性,比如name,data,methods,并不会往深层次验证
    ComponentOptions<HelloWorld>相当于是验证了this,而data内部的值无法验证
    <script lang="ts">
    import Vue, { ComponentOptions } from 'vue';
    interface HelloWorld extends Vue {
    msg: string
    }
    export default {
    name: 'HelloWorld',
    data (): object {
    return {
    msg: 1111 /* 这样也是不会报错的*/
    }
    }
    } as ComponentOptions<HelloWorld>
    </script>
    为了解决这个问题,需要用到vue-class-component插件
  7. vue-class-component插件的使用

    使用这个插件,你需要把组件定义成原生的js类和一个@Component修饰符
    安装这个插件
    <script lang="ts">
    import Vue from 'vue';
    import Component from 'vue-class-component';
    @Component({
    template: `
    <div class="hello">
    {{message}}
    </div>`
    })
    export default class HelloWorld extends Vue {
    message: string = 'Hello'
    mounted(){
    this.message = 'ye'
    }
    }
    </script>
    这种写法完美解决上面的问题,而且写法简洁
    @Component是一个es7的修饰符,用来给类添加成员
    要运行上面的代码,还要在tsconfig.json文件中添加配置
    "experimentalDecorators": true

typescript整合到vue中的详细介绍,ts+vue一梭子的更多相关文章

  1. 转:Http协议中Cookie详细介绍

    Http协议中Cookie详细介绍 Cookie总是保存在客户端中,按在客户端中的存储位置,可分为内存Cookie和硬盘Cookie.内存Cookie由浏览器维护,保存在内存中,浏览器关闭后就消失了, ...

  2. Vue.js——vue-resource详细介绍

    概述 Vue.js是数据驱动的,这使得我们并不需要直接操作DOM,如果我们不需要使用jQuery的DOM选择器,就没有必要引入jQuery.vue-resource是Vue.js的一款插件,它可以通过 ...

  3. vue中$nextTick详细讲解保证你一看就明白

    1.功能描述 今天我们要实现这个一个小功能: 页面渲染完成后展示一个div元素: 当点击这个div元素后: div元素消失: 出现一个input元素:并且input元素聚焦 想必大家我觉得简单,我们一 ...

  4. vue中的css作用域、vue中的scoped坑点

    一.css作用域 之前一直很困扰css的作用域问题,即使是模块化编程下,在对应的模块的js中import css进来,这个css仍然是全局的.导致在css中需要加上对应模块的html的id/class ...

  5. 关于Vue中main.js,App.vue,index.html之间关系进行总结

    在初始化的Vue项目中,我们最先接触到的就是main.js,App.vue,index.html这三个文件,我们从培训视频或者官方文档上可以了解到: index.html---主页,项目入口 App. ...

  6. vue中使用Ajax(axios)、vue函数中this指向问题

    Vue.js 2.0 版本推荐使用 axios 来完成 ajax 请求.Axios 是一个基于 Promise 的 HTTP 库,可以用在浏览器和 node.js 中. axios中文文档库:http ...

  7. vue中html、js、vue文件之间的简单引用与关系

    有关vue文件记录:index.html在html中运用组件 <body> <app></app> <!-- 此处app的组件为入口js main.js中定义 ...

  8. 关于 vue中 export default 和 new Vue({})

    对于刚开始学习vue的人(像我),一般都不会清楚的知道两者之间该怎么区分,甚至觉得两者是一样的. 那么,经过我的查证,发现两者之间是没有任何联系的. export default ES6 Module ...

  9. vue中keepalive怎么理解?​---vue中文社区

    vue中keepalive怎么理解? 说在前面: keep-alive是vue源码中实现的一个组件, 感兴趣的可以研究源码 https://github.com/vuejs/vue/blob/dev/ ...

随机推荐

  1. 【codevs3012+codevs3037】线段覆盖4+线段覆盖5(DP)

    线段覆盖4网址:http://codevs.cn/problem/3012/ 线段覆盖5网址:http://codevs.cn/problem/3037/ 题目大意:给出一条直线上的一坨线段,每条线段 ...

  2. spring mvc 对象型参数的传递(遇到坑了)

    直接来个列子: 这里设置了,contenType="application/json" 这里post 接收的参数对象. 但是问题来了: <html> <head& ...

  3. aodh M版本新特性 - queue between alarm evaluator and alarm notifier

    之前alarm evaluator service and alarm notifier services之间的通信采用RPC的方式,消耗较大,增加work queue的方式可以获得更好的性能, + ...

  4. Spring Boot入门——json数据处理

    1.引入fastJson插件 <!-- 引入fastjson插件 --> <dependency> <groupId>com.alibaba</groupId ...

  5. NAT(网络地址转换)协议

    NAT(Network Address Translator)是网络地址转换,它实现内网的IP地址与公网的地址之间的相互转换,将大量的内网IP地址转换为一个或少量的公网IP地址,减少对公网IP地址的占 ...

  6. Composer 入门使用手册

    依赖管理 官网地址:http://docs.phpcomposer.com/00-intro.html#Locally Composer 不是一个包管理器.是的,它涉及 "packages& ...

  7. 11-THREE.JS 相机始终朝向某个物体

    <!DOCTYPE html> <html> <head> <title></title> <script src="htt ...

  8. 分布式_理论_03_2PC

    一.前言 五.参考资料 1.分布式理论(三)—— 一致性协议之 2PC 2.分布式理论(三) - 2PC协议

  9. LeetCode OJ:Populating Next Right Pointers in Each Node II(指出每一个节点的下一个右侧节点II)

    Follow up for problem "Populating Next Right Pointers in Each Node". What if the given tre ...

  10. 团队开发中Git冲突解决

    正常来说我们团队协作开发过程中,冲突是常有的事,下面介绍下本人在开发中的解决办法. 冲突的主要原因就是由于我们开发人员在分支的同一位置写入了不一样的代码,然后合并到主干上导致我们冲突. 方法: 当冲突 ...