typescript整合到vue中的详细介绍,ts+vue一梭子
通过vue-cli命令行安装vue项目,注意不要eslint
安装依赖
cnpm install typescript --save-dev
cnpm install ts-loader --save-dev
在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
其余的配置不要动
新建指向文件
在项目的src跟目录中创建一个后缀为.d.ts的文件,此文件名称随意,我使用index
index.d.ts文件
写如下代码,表示声明一个模块,应用于所有的vue组件的import语句中
declare module "*.vue" {
import Vue from "vue";
export default Vue;
}
这个文件一旦声明,ts-loader就会找到Vue
新建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"
]
}
基本使用
<script lang="ts">
export default {
name: 'HelloWorld',
data (): object {
return {
msg: 'Welcome to Your Vue.js App'
}
}
}
</script>
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插件
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一梭子的更多相关文章
- 转:Http协议中Cookie详细介绍
Http协议中Cookie详细介绍 Cookie总是保存在客户端中,按在客户端中的存储位置,可分为内存Cookie和硬盘Cookie.内存Cookie由浏览器维护,保存在内存中,浏览器关闭后就消失了, ...
- Vue.js——vue-resource详细介绍
概述 Vue.js是数据驱动的,这使得我们并不需要直接操作DOM,如果我们不需要使用jQuery的DOM选择器,就没有必要引入jQuery.vue-resource是Vue.js的一款插件,它可以通过 ...
- vue中$nextTick详细讲解保证你一看就明白
1.功能描述 今天我们要实现这个一个小功能: 页面渲染完成后展示一个div元素: 当点击这个div元素后: div元素消失: 出现一个input元素:并且input元素聚焦 想必大家我觉得简单,我们一 ...
- vue中的css作用域、vue中的scoped坑点
一.css作用域 之前一直很困扰css的作用域问题,即使是模块化编程下,在对应的模块的js中import css进来,这个css仍然是全局的.导致在css中需要加上对应模块的html的id/class ...
- 关于Vue中main.js,App.vue,index.html之间关系进行总结
在初始化的Vue项目中,我们最先接触到的就是main.js,App.vue,index.html这三个文件,我们从培训视频或者官方文档上可以了解到: index.html---主页,项目入口 App. ...
- vue中使用Ajax(axios)、vue函数中this指向问题
Vue.js 2.0 版本推荐使用 axios 来完成 ajax 请求.Axios 是一个基于 Promise 的 HTTP 库,可以用在浏览器和 node.js 中. axios中文文档库:http ...
- vue中html、js、vue文件之间的简单引用与关系
有关vue文件记录:index.html在html中运用组件 <body> <app></app> <!-- 此处app的组件为入口js main.js中定义 ...
- 关于 vue中 export default 和 new Vue({})
对于刚开始学习vue的人(像我),一般都不会清楚的知道两者之间该怎么区分,甚至觉得两者是一样的. 那么,经过我的查证,发现两者之间是没有任何联系的. export default ES6 Module ...
- vue中keepalive怎么理解?---vue中文社区
vue中keepalive怎么理解? 说在前面: keep-alive是vue源码中实现的一个组件, 感兴趣的可以研究源码 https://github.com/vuejs/vue/blob/dev/ ...
随机推荐
- DS 和【ADDRESS】学习记录
CPU要读写一个内存单元的时候,必须先给出这个内存单元的地址. 内存单元由2部分组成. 8086CPU中,内存地址由以下组成. 1:段地址 2:偏移地址 8086CPU中,有一个DS寄存器地址,通常用 ...
- C# 反射通过GetCustomAttributes方法,获得自定义特性
http://blog.csdn.net/litao2/article/details/17633107 使用反射访问: 自定义属性的信息和对其进行操作的方法. 一.实例1 1.代码: 如:Syste ...
- html5笔记(标签)
1.aside aside字面理解为“旁边”,在html5中范围更广一点,是跟主内容相关,但是又可以独立的内容 ,可以是广告.引用.侧边栏等等. html5站的例子就是新闻的内容页或者列表页,以列表页 ...
- 配置标准的 ActiveMQ 组件
简单地说,使用 ActiveMQ 的方式是固定且直接的:启动 ActiveMQ 服务器,发送消息,接收消息.但你并未理解 ActiveMQ 背后运作的详情.在一些要求更高的场景里,需要理解并有能力自定 ...
- InnoDB并发事务
目录 1.行锁:索引加锁 2.意向锁 3.间隙锁 4.MVCC机制 行锁 InnoDB通过多版本并发控制MVCC来支持事务 InnoDB的设计是为了在处理大数据量的时候得到最好的性能.InnoDB存 ...
- jedis的源码理解-基础篇
[jedis的源码理解-基础篇][http://my.oschina.net/u/944165/blog/127998] (关注实现关键功能的类) 基于jedis 2.2.0-SNAPSHOT ...
- hive从查询中获取数据插入到表或动态分区
Hive的insert语句能够从查询语句中获取数据,并同时将数据Load到目标表中.现在假定有一个已有数据的表staged_employees(雇员信息全量表),所属国家cnty和所属州st是该表的两 ...
- MongoDB3.0 创建用户
use mydb db.createUser( { "user" : "sa", "pwd": "sa", " ...
- 深入javascript之原型和原型链
原型和原型链是js中的难点也是重点,明白了原型和原型链会让我们在后面不管是学习还是工作都会更加高效,并且原型和原型链会是面试中必不可少的话题.看完此篇文章一定会让你对原型,原型链有深刻全面的了解. 一 ...
- ES6环境配置
1.电脑有node环境,运行npm init 2.cnpm i -D babel-core babel-preset-es2015 babel-preset-latest 3.创建.babelrc文件 ...