vue3項(xiàng)目中引入ts的詳細(xì)圖文教程
提示:文章是基于vue3的項(xiàng)目基礎(chǔ)上引入ts
1.基于腳手架的情況下創(chuàng)建 vue3項(xiàng)目
vue create vue3-ts
選擇自定義預(yù)設(shè),ts設(shè)置未選中狀態(tài)
選擇yarn與npm啟動(dòng)項(xiàng)目(根據(jù)個(gè)人,在這里我選擇yarn)
2.啟動(dòng)未引入ts的vue3項(xiàng)目
3.在頁(yè)面中(HomeView.vue)引入ts
問(wèn)題一:
問(wèn)題二:
問(wèn)題一
在script 標(biāo)簽中引入ts后,會(huì)產(chǎn)生JSX語(yǔ)法錯(cuò)誤,這時(shí)我們需要引入ts(全局引用與局部引用)
第一步:
全局或者局部 引用Ts并通過(guò)tsc -v 查看版本號(hào) ts安裝成功,這里我直接在項(xiàng)目中 yarn add typescript
npm install -g typescript yarn add -g typescript(需要添加環(huán)境變量后 tsc-v生效)
注意:使用yarn全局引入后 需要配置環(huán)境變量后 tsc-v才生效
第二步:
命令生成ts配置文件tsconfig.json
tsc --init //生成 tsconfig.json
用以下內(nèi)容填充該文件,如有重復(fù),刪除此文件內(nèi)的重復(fù)項(xiàng)
{ "compilerOptions": { "outDir": "./built/", "sourceMap": true, "strict": true, "noImplicitReturns": true, "module": "es2015", "moduleResolution": "node", "target": "es5" }, "include": [ "./src/**/*" ] }
在 tsconfig.json 文件中設(shè)置 “jsx”:“preserve”,設(shè)置后發(fā)現(xiàn)還是報(bào)錯(cuò),(這里設(shè)置無(wú)效,如果設(shè)置有效下一步可以略過(guò),繼續(xù)百度)
第三步:在jsconfig.json 文件下添加與 jsx(jsx 屬性允許我們?cè)陧?xiàng)目中使用 .tsx 文件)
解決問(wèn)題二 (找不到模塊“XXX.vue”或其相應(yīng)的類型聲明)
在根目錄中創(chuàng)建 shims.d.ts文件
declare module '*.vue' { import { ComponentOptions } from 'vue' const componentOptions: ComponentOptions export default componentOptions } declare module '*'
我們也可以修改tsconfig.json 中替換 declare module ‘*’ 如下所示
"noImplicitAny": false, "allowJs": true,
嘗試打開項(xiàng)目會(huì)發(fā)現(xiàn)如下報(bào)錯(cuò)
解決方案:
安裝我們的依賴 確保安裝了 TypeScript、Webpack、Vue 和必要的加載程序。
安裝@vue/cli-plugin-typescript
@vue/cli-plugin-typescript內(nèi)部預(yù)置了ts-loader的配置,無(wú)需單獨(dú)配置(這一步是不是覆蓋掉)
yarn add @vue/cli-plugin-typescript --save-dev
安裝完畢后 嘗試打開項(xiàng)目
我們將 main.js 改為 main.ts {構(gòu)建成功}
我們嘗試注釋掉 shims.d.ts 中的 declare module ‘*’ 或者 替代他的 tsconfig文件中的
“noImplicitAny”: false, “allowJs”: true,
再次編譯項(xiàng)目會(huì)發(fā)現(xiàn)引入的router與store 沒(méi)有相應(yīng)的內(nèi)置類型文件,當(dāng)然main.js不會(huì)出現(xiàn)此問(wèn)題(個(gè)人理解)
修改回來(lái) tsconfig.json shims.d.ts我們進(jìn)行下一步
4.配置vue3+ts項(xiàng)目
我們可以看到在模塊文件中產(chǎn)生分號(hào)報(bào)錯(cuò),但是他并不會(huì)影響項(xiàng)目啟動(dòng),我們對(duì)typescript-eslint進(jìn)行配置
yarn add @typescript-eslint/eslint-plugin @typescript-eslint/parser --save-dev
yarn add @vue/eslint-config-typescript --save-dev
修改.eslintrc.js
module.exports = { extends: [ 'plugin:vue/vue3-essential', 'eslint:recommended', '@vue/typescript/recommended' ], plugins: [ 'vue', '@typescript-eslint' ], rules: { '@typescript-eslint/no-unused-vars': 'error', // 允許非空斷言 '@typescript-eslint/no-non-null-assertion': 'off', // 允許自定義模塊和命名空間 '@typescript-eslint/no-namespace': 'off', // 允許對(duì)this設(shè)置alias '@typescript-eslint/no-this-alias': 'off', // 允許使用any類型 '@typescript-eslint/no-explicit-any': ['off'], ...... } }
錯(cuò)誤解決
項(xiàng)目中會(huì)出現(xiàn)如下錯(cuò)誤
解決:在.eslintrc.js文件中添加以下代碼
5.其他配置
###vue.config.js配置 增加extension,引入 ts/tsx 文件時(shí)不必加后綴
module.exports = { chainWebpack: config => { config.resolve.extensions .add('ts') .add('tsx'); } }
在vscode中command+,打開settiings.json可配置保存時(shí)自動(dòng)eslint格式化
6.在HomeView.vue 使用Ts語(yǔ)法
<template> <div class="home"> <img alt="Vue logo" src="../assets/logo.png" /> <HelloWorld msg="Welcome to Your Vue.js App" /> </div> </template> <script setup lang="ts"> import { ref } from "vue"; import HelloWorld from "@/components/HelloWorld.vue"; interface Todo { id: number; title: string; isCompleted: boolean; } const aa = ref<Todo[]>([]) console.log(aa); const bb:boolean = false console.log(bb); </script>
總結(jié)
到此這篇關(guān)于vue3項(xiàng)目中引入ts的文章就介紹到這了,更多相關(guān)vue3項(xiàng)目引入ts內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在vue中獲取wangeditor的html和text的操作
這篇文章主要介紹了在vue中獲取wangeditor的html和text的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10Vue3使用時(shí)應(yīng)避免的10個(gè)錯(cuò)誤總結(jié)
Vue?3已經(jīng)穩(wěn)定了相當(dāng)長(zhǎng)一段時(shí)間了。許多代碼庫(kù)都在生產(chǎn)環(huán)境中使用它,其他人最終都將不得不遷移到Vue?3。我現(xiàn)在有機(jī)會(huì)使用它并記錄了我的錯(cuò)誤,下面這些錯(cuò)誤你可能想要避免2023-03-03vue addRoutes路由動(dòng)態(tài)加載操作
這篇文章主要介紹了vue addRoutes路由動(dòng)態(tài)加載操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08Vue項(xiàng)目接入Paypal實(shí)現(xiàn)示例詳解
這篇文章主要介紹了Vue項(xiàng)目接入Paypal實(shí)現(xiàn)示例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06Vue中ElementUI結(jié)合transform使用時(shí)彈框定位不準(zhǔn)確問(wèn)題解析
在近期開發(fā)中,需要將1920*1080放到更大像素大屏上演示,所以需要使用到transform來(lái)對(duì)頁(yè)面進(jìn)行縮放,但是此時(shí)發(fā)現(xiàn)彈框定位出錯(cuò)問(wèn)題,無(wú)法準(zhǔn)備定位到實(shí)際位置,本文給大家分享Vue中ElementUI結(jié)合transform使用時(shí)彈框定位不準(zhǔn)確解決方法,感興趣的朋友一起看看吧2024-01-01