vue3.0+ts引入詳細(xì)步驟以及語(yǔ)法校驗(yàn)報(bào)錯(cuò)問(wèn)題解決辦法
一、前言
前段時(shí)間學(xué)習(xí)了ts,于是用腳手架搭了個(gè)vue3.0+ts的項(xiàng)目,引入詳細(xì)步驟及語(yǔ)法校驗(yàn)報(bào)錯(cuò)解決辦法,整理下遇到的問(wèn)題以及解決辦法,分享給大家。
二、使用
1. 引入ts
Q:在vue項(xiàng)目中編寫tsx函數(shù)式組件提示報(bào)錯(cuò)。在沒(méi)有引入ts的項(xiàng)目中,寫tsx語(yǔ)法提示報(bào)錯(cuò)。無(wú)法使用 JSX,除非提供了 “–jsx” 標(biāo)志。ts(17004)

A:
- 先檢查是否安裝ts,cmd輸入 tsc -v, 顯示了版本號(hào)即安裝了ts;未安裝則執(zhí)行 npm install -g typescript,全局安裝ts;
- 下載依賴包 yarn add typescript @vue/cli-plugin-typescript;
- 添加tsconfig.json配置文件 。在項(xiàng)目目錄下控制臺(tái)輸入tsc --init,該目錄下生成tsconfig.json文件,內(nèi)容替換成以下:
{
"include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue", "src/main.js"],
"exclude": ["node_modules"],
"compilerOptions": {
"jsx": "preserve",
"noImplicitAny": false,
"allowJs": true,
"target": "es2016",
"module": "commonjs",
"baseUrl": "./",
"paths": {
"@/*": ["./src/*"]
},
"types": ["webpack-env"],
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"strict": true,
"skipLibCheck": true
},
}
- jsconfig.json 文件添加 “jsx”: “preserve” 配置項(xiàng)。
R: 問(wèn)題解決視圖

2 main.js 修改成 main.ts
Q: 控制臺(tái)報(bào)錯(cuò) Can’t resolve ‘./src/main.js’ in ‘F:\code\st\Vue\v3_ts’

A: 停止運(yùn)行后重新運(yùn)行npm run serve 即可
R: 運(yùn)行成功

3. 修改app.vue 后綴為 .tsx, 修改文件內(nèi)容
import { defineComponent } from 'vue'
export default defineComponent({
setup() {
return () => (
<router-view />
)
}
})
4. 組件引入less
使用import導(dǎo)入的方式引入,代碼如下:
import "./index.less"
export default (props, ctx) => {
return () => (
<span>123</span>
)
}
5. 組件引入圖片
使用import導(dǎo)入的方式引入,代碼如下:

Q:報(bào)錯(cuò)找不到模塊“./img/right.png”或其相應(yīng)的類型聲明。
A:在src目錄下新增文件 shims.d.ts 文件,內(nèi)容如下:
declare module '*.vue' {
import { ComponentOptions } from 'vue'
const componentOptions: ComponentOptions
export default componentOptions
}
declare module '*.less';
declare module '*.png';
declare module '*.json';
三、報(bào)錯(cuò)類型及解決辦法
Q:eslint 校驗(yàn)報(bào)錯(cuò)。
A: vue.config.js 中添加 lintOnSave:false 配置項(xiàng),重新運(yùn)行即可。
Q: 引入 less 報(bào)錯(cuò)。

A:未下載less依賴包,yarn add less less-loader即可。
Q:使用navigator.getUserMedia 提示報(bào)錯(cuò) 類型“Navigator”上不存在屬性“getUserMedia”;

A:在src目錄下 shims.d.ts 文件中添加如下內(nèi)容即可。
interface Navigator {
getUserMedia(
constraints: MediaStreamConstraints,
successCallback: NavigatorUserMediaSuccessCallback,
errorCallback: NavigatorUserMediaErrorCallback
): Promise<MediaStream>;
}
declare const navigator: Navigator;
- Q:使用dom獲取頁(yè)面元素,修改屬性值時(shí)報(bào)錯(cuò)。不能將類型“HTMLElement | null”分配給類型“HTMLVideoElement”。不能將類型“null”分配給類型“HTMLVideoElement”。
A:使用斷言,把獲取到的dom元素設(shè)置成 HTMLVideoElement 類型,代碼如下:
videoEle = document.getElementById("video") as HTMLVideoElement;
videoEle.srcObject = stream;
videoEle.onloadedmetadata = function (e) {
videoEle.play();
};
暫時(shí)遇到了這些,后續(xù)遇到其他語(yǔ)法報(bào)錯(cuò)的問(wèn)題再更新。
- Q: 父組件傳子組件非必傳參數(shù),在子組件中使用報(bào)錯(cuò)。類型“string | undefined”的參數(shù)不能賦給類型“string”的參數(shù)。
不能將類型“undefined”分配給類型“string”。
A: 使用斷言,設(shè)置成對(duì)應(yīng)類型,如
let placeholder = ref<string>(props?.placeholder as string)
- Q: 引入第三方j(luò)s,報(bào)錯(cuò) 找不到名稱“XLSX”。
A:在src目錄下 shims.d.ts 文件中添加如下內(nèi)容即可。
declare const XLSX: any;
- Q 使用父組件傳入的屬性報(bào)錯(cuò),property) s: string | undefined,對(duì)象可能為“未定義”。ts(2532)
A: 使用 let str = props.s as string; 變量接收屬性值后斷言成對(duì)應(yīng)類型的數(shù)據(jù)類型
import { defineComponent } from "vue";
import VP from "./components/poker"
interface Props {
s?: string
}
export default defineComponent({
props: {
s: {
type: String
}
},
setup(props: Props, ctx) {
let str = props.s as string;
return () => (
<>
{
str.split("").map(v => {
return (<VP></VP>)
})
}
</>
)
}
})附:Vue-cli3中使用TS完整代碼案例
<template>
<div class="test-container">
{{message}}
<input type="button" value="點(diǎn)擊觸發(fā)父級(jí)方法" @click="bindSend"/>
<input type="button" value="點(diǎn)擊觸發(fā)父級(jí)方法" @click="handleSend"/>
<input type="button" value="點(diǎn)擊觸發(fā)父級(jí)方法" @click="bindSend2"/>
<!-- <Hello></Hello> -->
</div>
</template>
<script lang="ts">
import { Component, Prop, Vue, Watch, Emit } from "vue-property-decorator";
import Hello from "./HelloWorld.vue";
// 注明此類為一個(gè)vue組件
@Component({
components: {
Hello
}
})
export default class Test extends Vue {
// 原有data中的數(shù)據(jù)在這里展開編寫
public message: string = "asd";
//原有props中的數(shù)據(jù)展開編寫
@Prop({
type: Number,
default: 1,
required: false
})
propA?: number
@Prop()
propB:string
//原有computed
public get computedMsg(){
return '這里是計(jì)算屬性' + this.message;
}
public set computedMsg(message:string){
}
//原有的watch屬性
@Watch('propA',{
deep:true
})
public test(newValue:string,oldValue:string){
console.log('propA值改變了' + newValue);
}
// 以前需要給父級(jí)傳值的時(shí)候直接方法中使用emit就行了,當(dāng)前需要通過(guò)emit來(lái)處理
@Emit()
private bindSend():string{
return this.message
}
@Emit()
private bindSend1(msg:string,love:string){
// 如果不處理可以不寫下面的,會(huì)自動(dòng)將參數(shù)回傳
// msg += 'love';
// return msg;
}
//原有放在methods中的方法平鋪出來(lái)
public handleSend():void {
this.bindSend1(this.message,'love');
}
// 這里的emit中的參數(shù)是表明父級(jí)通過(guò)什么接受,類似以前的$emit('父級(jí)定義的方法')
@Emit('test')
private bindSend2(){
return '這個(gè)可以用test接受';
}
}
</script>總結(jié)
到此這篇關(guān)于vue3.0+ts引入詳細(xì)步驟以及語(yǔ)法校驗(yàn)報(bào)錯(cuò)問(wèn)題解決辦法的文章就介紹到這了,更多相關(guān)vue3.0 ts 引入步驟及語(yǔ)法校驗(yàn)報(bào)錯(cuò)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue input輸入框中的值如何變成黑點(diǎn)問(wèn)題
這篇文章主要介紹了Vue input輸入框中的值如何變成黑點(diǎn)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
一篇文章告訴你如何實(shí)現(xiàn)Vue前端分頁(yè)和后端分頁(yè)
這篇文章主要為大家介紹了如何實(shí)現(xiàn)Vue前端分頁(yè)和后端分頁(yè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12
卸載vue2.0并升級(jí)vue_cli3.0的實(shí)例講解
在本篇文章里小編給大家整理的是關(guān)于卸載vue2.0并升級(jí)vue_cli3.0的實(shí)例內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。2020-02-02
解決vue2.0動(dòng)態(tài)綁定圖片src屬性值初始化時(shí)報(bào)錯(cuò)的問(wèn)題
下面小編就為大家分享一篇解決vue2.0動(dòng)態(tài)綁定圖片src屬性值初始化時(shí)報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03

