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

vue3.0+ts引入詳細(xì)步驟以及語法校驗(yàn)報(bào)錯(cuò)問題解決辦法

 更新時(shí)間:2024年01月28日 12:03:59   作者:拉風(fēng)的毛豆豆  
Vue?3.0是一個(gè)非常流行的JavaScript框架,不僅易于學(xué)習(xí)和使用,而且可以與許多UI框架集成,下面這篇文章主要給大家介紹了關(guān)于vue3.0+ts引入詳細(xì)步驟以及語法校驗(yàn)報(bào)錯(cuò)問題的解決辦法,需要的朋友可以參考下

一、前言

前段時(shí)間學(xué)習(xí)了ts,于是用腳手架搭了個(gè)vue3.0+ts的項(xiàng)目,引入詳細(xì)步驟及語法校驗(yàn)報(bào)錯(cuò)解決辦法,整理下遇到的問題以及解決辦法,分享給大家。

二、使用

1. 引入ts

Q:在vue項(xiàng)目中編寫tsx函數(shù)式組件提示報(bào)錯(cuò)。在沒有引入ts的項(xiàng)目中,寫tsx語法提示報(bào)錯(cuò)。無法使用 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: 問題解決視圖

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獲取頁面元素,修改屬性值時(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ù)遇到其他語法報(bào)錯(cuò)的問題再更新。

  • 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)前需要通過emit來處理
  @Emit()
  private bindSend():string{
      return this.message
  }
  @Emit()
  private bindSend1(msg:string,love:string){
      // 如果不處理可以不寫下面的,會(huì)自動(dòng)將參數(shù)回傳
    //   msg += 'love';
    //   return msg;
  }
  //原有放在methods中的方法平鋪出來
  public handleSend():void {
      this.bindSend1(this.message,'love');
  }
  // 這里的emit中的參數(shù)是表明父級(jí)通過什么接受,類似以前的$emit('父級(jí)定義的方法')
  @Emit('test')
  private bindSend2(){
      return '這個(gè)可以用test接受';
  }
}
</script>

總結(jié) 

到此這篇關(guān)于vue3.0+ts引入詳細(xì)步驟以及語法校驗(yàn)報(bào)錯(cuò)問題解決辦法的文章就介紹到這了,更多相關(guān)vue3.0 ts 引入步驟及語法校驗(yàn)報(bào)錯(cuò)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue組件之自定義事件的功能圖解

    Vue組件之自定義事件的功能圖解

    本文通過圖文并茂的形式給大家介紹了Vue組件之自定義事件的功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • vue實(shí)現(xiàn)列表的添加點(diǎn)擊

    vue實(shí)現(xiàn)列表的添加點(diǎn)擊

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)列表的添加點(diǎn)擊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Vue之Dep和Observer的用法及說明

    Vue之Dep和Observer的用法及說明

    這篇文章主要介紹了Vue之Dep和Observer的用法及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue input輸入框中的值如何變成黑點(diǎn)問題

    Vue input輸入框中的值如何變成黑點(diǎn)問題

    這篇文章主要介紹了Vue input輸入框中的值如何變成黑點(diǎn)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 一篇文章告訴你如何實(shí)現(xiàn)Vue前端分頁和后端分頁

    一篇文章告訴你如何實(shí)現(xiàn)Vue前端分頁和后端分頁

    這篇文章主要為大家介紹了如何實(shí)現(xiàn)Vue前端分頁和后端分頁,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • vue修改滾動(dòng)條樣式的方法

    vue修改滾動(dòng)條樣式的方法

    這篇文章主要介紹了vue修改滾動(dòng)條樣式,首先要知道,修改滾動(dòng)條樣式,利用偽元素-webkit-scrollbar。下面來看看文章內(nèi)容的具體實(shí)現(xiàn)吧
    2021-11-11
  • 卸載vue2.0并升級(jí)vue_cli3.0的實(shí)例講解

    卸載vue2.0并升級(jí)vue_cli3.0的實(shí)例講解

    在本篇文章里小編給大家整理的是關(guān)于卸載vue2.0并升級(jí)vue_cli3.0的實(shí)例內(nèi)容,需要的朋友們可以學(xué)習(xí)參考下。
    2020-02-02
  • 60個(gè)vue常用工具類

    60個(gè)vue常用工具類

    這篇文章主要介紹了60個(gè)vue常用工具類,包括vue郵箱驗(yàn)證,vue瀏覽器識(shí)別,vue操作系統(tǒng)識(shí)別,vue html過濾,vue身份證校驗(yàn)等需要的朋友可以參考下
    2023-01-01
  • vue3+ts使用bus事件總線的示例代碼

    vue3+ts使用bus事件總線的示例代碼

    這篇文章主要介紹了vue3+ts使用bus事件總線,文中給大家提到了vue總線機(jī)制(bus)的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 解決vue2.0動(dòng)態(tài)綁定圖片src屬性值初始化時(shí)報(bào)錯(cuò)的問題

    解決vue2.0動(dòng)態(tài)綁定圖片src屬性值初始化時(shí)報(bào)錯(cuò)的問題

    下面小編就為大家分享一篇解決vue2.0動(dòng)態(tài)綁定圖片src屬性值初始化時(shí)報(bào)錯(cuò)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評(píng)論