温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

在Vue.js中如何使用TypeScript

发布时间:2021-02-25 10:09:31 来源:亿速云 阅读:396 作者:清风 栏目:web开发

这篇文章主要为大家展示了在Vue.js中如何使用TypeScript,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“在Vue.js中如何使用TypeScript”这篇文章吧。

vue是什么软件

Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

虽然 vue2.x 对TypeScript的支持还不是非常完善,但是从今年即将到来的3.0版本在GitHub上的仓库 vue-next 看,为TS提供更好的官方支持应该也会是一个重要特性,那么,在迎接3.0之前,不妨先来看看目前版本二者的搭配食用方法吧~

创建项目

  • 虽然GitHub上有各种各样相关的Starter,但是使用 Vue CLI 应该是目前相对比较好的方式,在使用 vue create 创建新项目时,对 preset 选择 Manually select features 选项,之后添加 TypeScript

  • 如果想在vue应用中完整使用ES6中提供的类特性,那么在 class-style component syntax 处选择Y(本文主要介绍选择Y的情况)

  • 对于 Babel 来说,一般情况选择使用,而 linter / formatter 的具体选择可根据项目需求,此处不多说明

进入项目

创建完成后,看一看 package.json ,可以发现 vue-class-componentvue-property-decorator 以及其他ts相关的modules都已被添加,其中: vue-class-component 可以让你使用class-style语法创建组件,比如以下代码:

<template>  <div>  <button @click="decrement">-</button>  {{ count }}  <button @click="increment">+</button>  </div> </template> <script lang="ts">  import Vue from 'vue'  import Component from 'vue-class-component'  // Define the component in class-style  @Component  export default class Counter extends Vue {  // Class properties will be component data  count = 0  // Methods will be component methods  increment() {   this.count++  }  decrement() {   this.count--  }  } </script>

vue-property-component 则完全依赖于前者,提供了除 @Component 外的其他几种装饰器,比如 @Prop

import { Vue, Component, Prop } from 'vue-property-decorator'  @Component  export default class YourComponent extends Vue {  @Prop(Number) readonly propA: number | undefined  @Prop({ default: 'default value' }) readonly propB!: string  @Prop([String, Boolean]) readonly propC: string | boolean | undefined }

再来一个二者结合的简单例子吧:

<template>  <div class="hello">  <h2>{{ msg }}</h2>  <h2>{{ fullName }}</h2>  <button @click="reverseStr()">Reverse</button>  </div> </template> <script lang="ts"> import { Component, Prop, Vue, Watch } from 'vue-property-decorator'; @Component export default class HelloWorld extends Vue {  @Prop() private msg!: string;  firstName = "rapt";  lastName = "azure";  mounted() {  console.log('mounted');  }  // Computed property  get fullName(): string {  return this.firstName + this.lastName;  }  // Method  reverseStr() {  this.firstName = this.firstName.split('').reverse().join('');  this.lastName = this.lastName.split('').reverse().join('');  } } </script>
  • 此时,你的vue项目已经有fully-typed的可能了,当然也会有更好的自动补全以及错误提示。

  • 为了更好的确定类型,可以创建例如 interfaces 这样的文件夹,充分利用ts的接口和类来使项目有更好的组织结构,可读性和维护性。

另一种选择

其实当然也可以不使用class风格啦,这样的话,就和平时熟悉的vue更为相似了,而对类型当然也是完全支持的。
这里也提供一个简单的例子吧~<template>

<div class="hello">   <h2>{{ msg }}</h2>   <h2>{{ test }}</h2>  </div> </template> <script lang="ts"> import Vue from 'vue'; export default Vue.extend({  name: 'HelloWorld',  props: {   msg: String,  },  data() {   return {    test: "Hello from TS" as string   }  },  methods: {   pressMe(): string {    return this.test + 'br'   }  } }); </script>

其他的话

  • 本文只是简要探讨了在Vue.js中使用TypeScript的可能性,更多的相关内容在 官方文档 里可以找到哦,或者也可以多去Github的Vue区,TS区逛逛呢~

  • TypeScript的出现为JavaScript的生态带来了新活力,不管是前端三大框架Vue,React,Angular,还是Node系的后端框架比如Nest和Express,都在积极拥抱TS,希望以后整个生态会发展得越来越好吧~

以上就是关于“在Vue.js中如何使用TypeScript”的内容,如果改文章对你有所帮助并觉得写得不错,劳请分享给你的好友一起学习新知识,若想了解更多相关知识内容,请多多关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI