在 Vue 中使用 Typescript

来源:https://www.cnblogs.com/eightFlying/archive/2020/01/16/vue_typescript.html
-Advertisement-
Play Games

本篇不會過多講述 ts 語法,著重記錄下 在 Vue 中使用 ts 的方法以及踩坑經過。 ...


前言

  恕我直言,用 Typescript 寫 Vue 真的很難受,Vue 對 ts 的支持一般,如非萬不得已還是別在 Vue 裡邊用吧,不過聽說 Vue3 會增強對 ts 的支持,正式登場之前還是期待一下吧嘻嘻。

  本篇不會過多講述 ts 語法,著重記錄下 在 Vue 中使用 ts 的方法以及踩坑經過。

  如果是使用 Vue Cli2 搭建的項目,要註意 webpack 版本可能與 ts-loader 版本不匹配,可以降低 ts-loader 版本到 3.0+ 或者 將 webpack升級到 4.0+ (本篇所用版本 [email protected] + [email protected])

主要步驟

  1. 先要讓 vue 項目可以識別 .ts 文件。安裝關鍵依賴 npm i typescript ts-loader -D

  2. 在 webpack.base.config.js 中添加 ts-loader

//resolve.extensions 裡面加上.ts 尾碼 之後引入.ts的時候可以不寫尾碼
{
  test: /\.tsx?$/,
  loader: 'ts-loader',
  exclude: /node_modules/,
  options: { 
    appendTsSuffixTo: [/\.vue$/], //關鍵
  }
}

  3. 在根目錄建tsconfig.json文件 下麵的配置僅供參考

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

  4. 接著需要確保在 vue 中可以正常使用 ts 。安裝 vue-class-component(為vue組件提供修飾器) vue-property-decorator(更多的結合vue特性的修飾器) [ tslint tslint-loader tslint-config-standard(可選 約束.ts/.tsx代碼格式)],這樣就可以在 vue 文件中使用諸如 @Component、@Prop等裝飾器了。註意:.vue 文件中的 script 標簽要加上 lang="ts"。關於 裝飾器的使用可以參看下這位大哥的文章:https://segmentfault.com/a/1190000019906321

<template>
    <div class="count-down" v-html="countDown(endDate)">
    </div>
</template>

<script lang="ts">
import { Component, Prop, Vue, Emit } from "vue-property-decorator"
import moment from 'moment'

@Component
export default class CountDown extends Vue {
    @Prop() endDate!: string
    // 變數後加!是非空斷言

    now: any = moment()
    mounted() {
        setInterval((): void =>{
            this.now = moment()
        },1000)
    }
    destroyed() {
        
    }
    get countDown(): object{
        return function(endDate: any): string {
            let m1: any = this.now
            let m2: any = moment(endDate)
            let du: any = moment.duration(m2 - m1, 'ms')
            let hours: number = du.get('hours')
            let mins: number = du.get('minutes')
            let ss: number = du.get('seconds')
            if(hours <= 0 && mins <= 0 && ss <= 0) {
                // this.$emit('timeout')
                this.timeout()
                return "今日已結束"
            }else {
                return `${this.PrefixInteger(hours,2)} <span style="font-size: 16px;">小時</span> ${this.PrefixInteger(mins,2)} <span style="font-size: 16px;">分鐘</span><span style="color: #F56C6C;"> ${this.PrefixInteger(ss,2)} </span><span style="font-size: 16px;">秒</span>`
            }
        }
    }

    @Emit()
    timeout(){}

    
    //數字前補 0 
    // num傳入的數字,n需要的字元長度
    PrefixInteger(num: number, n: number): string {
        return (Array(n).join('0') + num).slice(-n)
    }
}
</script>

<style lang="less" scoped>
//...
</style>

 

  5. 將main.js 變成 main.ts 並且在 webpack.base.conf.js 修改入口為main.ts,這一步至關重要。

  6. 在 src 目錄下新建文件 shims-vue.d.ts ,告訴 TypeScript *.vue 尾碼的文件可以交給 vue 模塊來處理,註意 在代碼中導入 *.vue 文件的時候,需要寫上 .vue 尾碼,這裡可以參考官網說明:增強類型以配合插件使用

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

踩坑記錄

  1. 報錯如下,報錯原因一是沒有將入口文件改成 ts,二是 webpack.base.conf.js 中引入 ts-loader 錯誤,沒有加上 options: { appendTsSuffixTo: [/\.vue$/], }

Module build failed: Error: Could not find source file: 'XXX/src/App.vue'.

  2. 全局屬性報錯 如 Vue.prototype.$msg = XXX,需要將全局屬性在 .d.ts 文件中聲明

import Vue from "vue";
import { AxiosInstance } from "axios";
import { ElMessage } from "element-ui/types/message";

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

declare module 'vue/types/vue' {
    interface Vue {
        $http: AxiosInstance,
        $message: ElMessage
    }
}

  3. 使用上面這種聲明全局屬性的方式又會帶來新的問題,報錯 import App from './App.vue'處,找不到 App.vue 這個模塊,雖然不影響編譯,但是這紅色的波浪線就像老鼠屎,看著那叫一個難受呀。解決方法:將 shims-vue.d.ts 文件一分為二,將全局屬性聲明和 Vue 的聲明分離;在 shims-vue.d.ts 文件同級目錄下新建 vue.d.ts(名字不一定叫 vue,如 xxx.d.ts 也可以);關鍵是要將以下代碼放在單獨的 .d.ts 文件中

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

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 問題描述:現場一臺測試伺服器,安裝有oracle11g(11.2.0.1),上午還運行正常,結果下午直接訪問不了,提示錯誤:ora-12541 無監聽程式問題。問題排查:按照常規方法,重啟監聽程式以及資料庫、重新配置監聽程式均無作用,後來發現是listener.log日誌文件過大(達到4G,據說這是... ...
  • 利用空閑時間花幾分鐘回顧一下 7.1 檢索數據 為了查詢出資料庫表中的行(數據),使用SELECE語句。 格式: 第一種寫法使用\ 通配符,會把表中行的列全部查詢出來,而不必取一一列出全部列。但是不推薦使用,這跟INSERT語句的規範寫法一樣。 使用\ 通配符,列的順序一般是列在表定義中出現的順序, ...
  • 最近在自學看 資料庫系統概論 這本書,總結一下遇到的問題。 1.廣義笛卡爾積(Extende cartesian product): 屬於 關係代數 裡面的 傳統的集合運算。其他的為union,except,intersection. 詳情不提了,舉個例子就是: create table R(A c ...
  • 個人博客 "http://www.milovetingting.cn" 位運算的簡單應用 許可權管理 位運算在實際的開發中,有很多巧妙的應用場景。如: 1. 一個存放正整數的數組,裡面有一個數字只出現一次,其它數字都出現兩次,求只出現一次的數字。 2. 不用臨時變數,交換兩個數字的值。 3. Andr ...
  • 打開項目文件夾下 'node_modules/react native/local cli/runIOS/findMatchingSimulator.js' 查找 修改為 查找 修改為 原方法地址 https://github.com/facebook/react native/issues/214 ...
  • 註:參數content為生成二維碼bitmap的內容,該二維碼bitmap在和文本title組合生成一個新的bitmap ...
  • 在Vue進行前端開發中,條件判斷主要用於根據不同的條件來決定顯示或隱藏,或者進行視圖之間的切換,本文以一個簡單的小例子簡述v-if的常見用法,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 方案一 方案二:用context context特性 記住一串單片語合 前3個、後3個、後兩個 一個方法、兩個靜態屬性 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...