这篇文章将为大家详细讲解有关vue-cli3+typescript的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
vue-cli3
vue-cli3的详细功能推荐官方文档,不在本文介绍范围内。
安装:
npm install -g @vue/cli
检查安装成功与否:
vue --version
创建项目:
vue create myapp
可以选择Manually select feature
来自由选择功能,常用的有vuex、vue-router、CSS Pre-processors等,我们再把typescript勾上,就可以回车进入下一步了。PS:勾选的操作是按空格键。
创建成功之后,执行启动命令:
npm run serve
就可以通过http://localhost:8080/
访问本地项目啦。
typescript
如果没有typescript基础,可以先补补课,大概花三十分钟就可以了解typescript的一些特性,比如:TypeScript 入门教程。
ts最主要的一点就是类型定义,有个概念才好看得懂demo。
vue-property-decorator
这是一个涵盖了vue的一些对象的集合,我们可以从这里取一些东西出来:
import { Component, Prop, Vue, Watch } from 'vue-property-decorator';
取出来的这几个属性,分别是 组件定义Component
,父组件传递过来的参数Prop
,原始vue对象Vue
,数据监听对象Watch
。还包括这里没有列举出来的Model
,Emit
,Inject
,Provide
,可以自己尝试下。
demo
<template>
<div class="hello">
<h2>{{ msg }}--{{ names }}</h2>
<input type="text" v-model="txt">
<p>{{ getTxt }}</p>
<button @click="add">add</button>
<p>{{ sum }}</p>
</div>
</template>
<script lang="ts">
import { Component, Prop, Vue, Watch } from 'vue-property-decorator';
@Component
export default class HelloWorld extends Vue {
//props
@Prop() private msg!: string
@Prop() private names!: string
//data
private txt: string = '1'
private sum: number = 0
//computed
get getTxt(){
return this.txt
}
//methods
private add(){
this.sum++
console.log(`sum : ${this.sum}`)
}
//生命周期
created(){
console.log('created')
}
//watch
@Watch('txt')
changeTxt(newTxt: string, oldTxt: string){
console.log(`change txt: ${oldTxt} to ${newTxt}`)
}
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped lang="less">
h4 {
margin: 40px 0 0;
}
input {
width: 240px;
height: 32px;
line-height: 32px;
}
</style>
以上就是demo,代码组织有点散,没有原来js书写的整齐。
这个demo没有引入组件,如果需要引入组件,应该这样书写:
<template>
<div class="home">
<img alt="Vue logo" src="../assets/logo.png">
<HelloWorld msg="Welcome to Your Vue.js + TypeScript App" names="aaa" />
<HelloWorld2 msg="Welcome to Your Vue.js + TypeScript App" names="bbb" />
</div>
</template>
<script lang="ts">
import { Component, Vue } from 'vue-property-decorator';
import HelloWorld from '@/components/HelloWorld.vue'; // @ is an alias to /src
import HelloWorld2 from '@/components/HelloWorld2.vue'; // @ is an alias to /src
@Component({
components: {
HelloWorld,
HelloWorld2,
},
})
export default class Home extends Vue {}
</script>
结语
如果VSCode编辑器有警告提示,比如:
Experimental support for decorators is a feature that is subject to change in a future release. Set the 'experimentalDecorators' option to remove this warning.
可以把工作区其他的项目移除,或者把本项目拖动到工作区的首位,或者在把本项目的tsconfig.json复制到工作区首位的项目的根目录下,重启编辑器,有比较大的概率可以解决警告提示。
关于“vue-cli3+typescript的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。