欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue2 Vue-cli中使用Typescript的配置詳解

 更新時間:2017年07月24日 10:03:11   作者:彩色的豆  
Vue作為前端三大框架之一截至到目前在github上以收獲44,873顆星,足以說明其以悄然成為主流。下面這篇文章主要給大家介紹了關(guān)于Vue2 Vue-cli中使用Typescript的配置的相關(guān)資料,需要的朋友可以參考下。

前言

因為最近公司的團隊熱衷于vue框架,新項目想著練練typescript,于是開始了vue+ts的踩坑之路...本文意在為和我有一樣想法的伙伴們省去踩坑的時間,下面話不多說了,來一起看看關(guān)于Vue2 Vue-cli中利用Typescript需要的配置是什么吧。

一、初步配置

首先安裝官方插件vue-class-component,vue-property-decorator,配置webpack。
webpack配置如下:

修改入口文件

entry: {
 app: './src/main.ts'
}

resolve部分:

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

配置loader

{
 test: /\.tsx?$/,
 loader: 'ts-loader',
 exclude: /node_modules/,
 options: {
  appendTsSuffixTo: [/\.vue$/],
 }
 }

配置tsconfig.json

{
 "include": [
 "src/**/*"
 ],
 "exclude": [
 "node_modules"
 ],
 "compilerOptions": {
 "allowSyntheticDefaultImports": true,
 "experimentalDecorators": true,
 "allowJs": true,
 "module": "es2015",
 "target": "es5",
 "moduleResolution": "node",
 "experimentalDecorators": true,
 "isolatedModules": true,
 "lib": [
  "dom",
  "es5",
  "es2015.promise"
 ],
 "sourceMap": true,
 "pretty": true
 }
}

二、實戰(zhàn)!

配好配置只是第一步,在項目里跑起來才是王道。

在vue文件的script標簽里添加lang='ts'

因為ts-loader不像配過loader的webpack一樣知道vue,html等文件是什么東西,你跑起來后會報模塊無法解析的錯誤,所以還需要配置.d.ts聲明文件

vue的如下配置

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

你也可以為其它的非js模塊配置.d.ts文件如html(告訴ts-loader把html理解成字符串)

declare module "*.html" {
 let template: string;
 export default template;
}

配置好之后ts就能理解這些模塊了

從vue-property-decorator引入需要用到的模塊

(一般只用到Component, Vue, Watch, Prop這四個,其它3個沒用到也沒研究,知道的大佬可以解釋下。)

import { Component, Vue, Watch } from 'vue-property-decorator'

這里拿之前寫的sidbar的代碼當個栗子:

class HoverTopElem {
 leaveTop: number = -200
 top: number = null
 height: number = null

 show(e) {
 this.top = e.target.getBoundingClientRect().top
 this.height = e.target.clientHeight
 }
 hidden() {
 this.top = this.leaveTop
 }
}

@Component({
 name: 'sidebar',
 template: template,
 components: {
 sidebarItem
 }
})
export default class Sidebar extends Vue {
 SidebarMenu: any = SidebarMenu
 hoverTopElem: HoverTopElem = new HoverTopElem()
 activeListItemName: string = null
 activeRouteItemRoute: string = null

 get _activeRouteItemRoute(): string {
 return this.$route.path
 }

 @Watch('_activeRouteItemRoute', { immediate: true })
 onRouteChanged(val: any) {
 this.activeRouteItemRoute = val
 }

 changeList(param) {
 this.activeListItemName = param
 }

 changeRoute(param) {
 this.activeRouteItemRoute = param
 }
}

元數(shù)據(jù)寫在@Component配置里,像名字,用到的組件啥的,然后說下之前vue里用到的各個實例屬性方法在這里怎么用:

data: 這個是最常用的,像上面的SidebarMenu(這里一共聲明了4個),注意這里聲明的變量一定要賦一個值,沒有就null,不能是undefined,不然這個數(shù)據(jù)就不是響應(yīng)的。因此HoverTopElem類里的屬性也是要有初始值,不然這些屬性也不是響應(yīng)的

computed: 這里就是get函數(shù),注意tsconfig.jsonp不配置"target": "es5"這里會報錯

prop: vue-property-decorator里面有Prop模塊,也可以在元數(shù)據(jù)聲明這個prop,然后在類里聲明一下這個變量就可以了,個人推薦第一種

watch: vue-property-decorator里的Watch模塊

methods: 方法像data一樣直接寫在類里就可以了(注意不要和周期鉤子同名)

各種生命周期鉤子: 直接寫就行

路由鉤子見vue-class-component文檔

至此,基本就可以像原來一樣寫vue組件了。

當然如果要想和原來一樣寫ts,還需要配置tslint,不然一些ts語法不會被識別,像public修飾符之類的,因為ts還不是很熟練就沒想著配,有興趣的朋友可以試試。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Vue混入mixins滾動觸底的方法

    Vue混入mixins滾動觸底的方法

    這篇文章主要介紹了Vue混入mixins滾動觸底的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • vue如何使用pdf.js實現(xiàn)在線查看pdf文件功能

    vue如何使用pdf.js實現(xiàn)在線查看pdf文件功能

    PDF.js是一個開源的JavaScript庫,用于在網(wǎng)頁上渲染和顯示PDF文件,在Vue中使用PDF.js來預覽PDF文件是很常見的需求,這篇文章主要給大家介紹了關(guān)于vue如何使用pdf.js實現(xiàn)在線查看pdf文件功能的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • vue實現(xiàn)淘寶購物車功能

    vue實現(xiàn)淘寶購物車功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)淘寶購物車功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 關(guān)于Vue虛擬dom問題

    關(guān)于Vue虛擬dom問題

    這篇文章主要介紹了Python合成Excel表的實現(xiàn)代碼(多sheet),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • uniapp和vue如何獲取屏幕或盒子內(nèi)容的寬高

    uniapp和vue如何獲取屏幕或盒子內(nèi)容的寬高

    在實際開發(fā)中我們會遇到不確定高度的情況,下面這篇文章主要給大家介紹了關(guān)于uniapp和vue如何獲取屏幕或盒子內(nèi)容的寬高,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • vue3封裝echarts圖表數(shù)據(jù)無法渲染到頁面問題

    vue3封裝echarts圖表數(shù)據(jù)無法渲染到頁面問題

    這篇文章主要介紹了vue3封裝echarts圖表數(shù)據(jù)無法渲染到頁面問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • Vue單頁面應(yīng)用中實現(xiàn)Markdown渲染

    Vue單頁面應(yīng)用中實現(xiàn)Markdown渲染

    這篇文章主要介紹了Vue單頁面應(yīng)用中如何實現(xiàn)Markdown渲染,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2021-02-02
  • 淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    本文主要介紹了淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • elementUI中Table表格問題的解決方法

    elementUI中Table表格問題的解決方法

    這篇文章主要給大家介紹了關(guān)于elementUI中Table表格問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-12-12
  • Vue 頁面權(quán)限控制和登陸驗證功能的實例代碼

    Vue 頁面權(quán)限控制和登陸驗證功能的實例代碼

    這篇文章主要介紹了Vue 頁面權(quán)限控制和登陸驗證功能的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06

最新評論