vue | 不同 vue 版本對復雜泛型的支持情況 · vue3.2 VS vue3.5

省流總結defineProps泛型能力,來直接推導第三方組件的 props 類型

引入第三方庫的類型,并直接在 <script setup> 中作為 props 使用。這種類型一般是復雜泛型(包含聯合類型、可選屬性、交叉類型、條件類型)。

特性Vue 3.2Vue 3.5(或 Vue 3.3+)
泛型類型識別? 可識別? 可識別
defineProps<泛型>() 支持? 支持,但弱? 支持完整
模板中類型提示(TS 提示)? 無提示或不完整? 完整提示
第三方庫類型支持(復雜類型)?? 需要手動檢查? 可放心使用

問題:同一句代碼,在不同版本中的差異。

在vue3.2出現了報錯,即不支持第三方的類型;vue3.5可以直接使用,不存在報錯。

報錯語句:

import type { FontAwesomeIconProps } from '@fortawesome/vue-fontawesome'
defineProps<FontAwesomeIconProps>()

?vue3.2中的?報錯內容:[@vue/compiler-sfc] type argument passed to defineProps() must be a literal type, or a reference to an interface or literal type.

?


?分析 —— 不同版本對復雜泛型的支持情況:

import type { FontAwesomeIconProps } from '@fortawesome/vue-fontawesome'
defineProps<FontAwesomeIconProps>()

使用了 defineProps泛型能力,來直接推導第三方組件的 props 類型

引入第三方庫的類型FontAwesomeIconProps),并直接在 <script setup> 中作為 props 使用。這種類型一般是復雜泛型(包含聯合類型、可選屬性、交叉類型、條件類型)。


🧩 Vue 3.2 的支持情況

? 可以使用,但存在以下限制

  1. 類型可以正常識別,不會報錯;

  2. 模板中不會獲得完整的類型提示,例如 iconspin 這些 props,VSCode 無法自動補全或做類型檢查

  3. 類型系統在 <script setup> 中并不會很好地將 defineProps<T>() 的泛型映射到 template

  4. @vue/compiler-sfcvue-tsc defineProps<T>() 泛型的推導能力有限

? 示例效果(Vue 3.2)

<script setup lang="ts">
import type { FontAwesomeIconProps } from '@fortawesome/vue-fontawesome'
const props = defineProps<FontAwesomeIconProps>()// 這里 props 有類型提示,但 template 中沒有
</script><template><FontAwesomeIcon :icon="icon" /> <!-- ? icon 無提示,甚至報錯 -->
</template>


🧩 Vue 3.5 的支持情況(或 Vue 3.3+)

? 支持非常完整

  1. defineProps<FontAwesomeIconProps>()被完全推導

  2. VSCode / Volar 插件會在 <template> 中提供準確的類型提示

  3. 即使 FontAwesomeIconProps復雜類型(比如嵌套、聯合、交叉),也能推導成功

  4. <script setup generic> 可以配合使用,如果你需要泛型組件

? 示例效果(Vue 3.5)

<script setup lang="ts">
import type { FontAwesomeIconProps } from '@fortawesome/vue-fontawesome'const props = defineProps<FontAwesomeIconProps>()
</script><template><FontAwesomeIcon :icon="props.icon" :spin="props.spin" /> <!-- ? 全都有類型提示 -->
</template>

或者直接在模板中使用:

<template><FontAwesomeIcon v-bind="props" /> <!-- ? 類型也能傳遞 -->
</template>

? 總結對比

特性Vue 3.2Vue 3.5(或 Vue 3.3+)
泛型類型識別? 可識別? 可識別
defineProps<泛型>() 支持? 支持,但弱? 支持完整
模板中類型提示(TS 提示)? 無提示或不完整? 完整提示
第三方庫類型支持(復雜類型)?? 需要手動檢查? 可放心使用

建議:

如果你正在使用 FontAwesomeIconProps 這種復雜泛型作為 defineProps 的泛型參數,并希望:

  • 保證 props 類型安全

  • <template> 中獲得提示、補全

  • 更好維護和復用

請升級至 Vue 3.3 或 3.5,搭配 TypeScript 5.x最新的 Volar 插件,體驗會好很多。


?vue3.2中引入第三方類型,如何解決?

創建獨立的別名,并復制拷貝所參考的第三方庫的屬性。

將原先的寫法(注釋部分),改成 引入創建的別名

?即可成功顯示!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/78111.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/78111.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/78111.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Unity-無限滾動列表實現Timer時間管理實現

今天我們來做一個UI里經常做的東西&#xff1a;無限滾動列表。 首先我們得寫清楚實現的基本思路&#xff1a; 所謂的無限滾動當然不是真的無限滾動&#xff0c;我們只要把離開列表的框再丟到列表的后面就行&#xff0c;核心理念和對象池是類似的。 我們來一點一點實現&#x…

Docker的基本概念和一些運用場景

Docker 是一種開源的容器化平臺&#xff0c;可以幫助開發人員更加高效地打包、發布和運行應用程序。以下是 Docker 的基本概念和優勢&#xff1a; 基本概念&#xff1a; 容器&#xff1a;Docker 使用容器來打包應用程序及其依賴項&#xff0c;容器是一個獨立且可移植的運行環境…

Unity中基于第三方插件擴展的對于文件流處理的工具腳本

在Unity的項目中對應文件處理,在很多地方用到,常見的功能,就是保存文件,加載文件,判斷文件或者文件夾是否存在,刪除文件等。 在之前已經寫過通過C#的IO實現的這些功能,可查看《Unity C# 使用IO流對文件的常用操作》,但是不能保證所有平臺都可以使用 現在基于第三方跨…

Flink介紹——實時計算核心論文之MillWheel論文詳解

引入 通過前面的文章&#xff0c;我們從S4到Storm&#xff0c;再到Storm結合Kafka成為當時的實時處理最佳實踐&#xff1a; S4論文詳解S4論文總結Storm論文詳解Storm論文總結Kafka論文詳解Kafka論文總結 然而KafkaStorm的第一代流式數據處理組合&#xff0c;還面臨的三個核心…

python異步協程async調用過程圖解

1.背景&#xff1a; 項目中有用到協程&#xff0c;但是對于協程&#xff0c;線程&#xff0c;進程的區別還不是特別了解&#xff0c;所以用圖示的方式畫了出來&#xff0c;用于理清三者的概念。 2.概念理解&#xff1a; 2.1協程&#xff0c;線程&#xff0c;進程包含關系 一…

【React】獲取元素距離頁面頂部的距離

文章目錄 代碼實現 代碼實現 import { useEffect, useRef, useState } from react;const DynamicPositionTracker () > {const [distance, setDistance] useState(0);const divRef useRef(null);useEffect(() > {const targetDiv divRef.current;if (!targetDiv) re…

26.OpenCV形態學操作

OpenCV形態學操作 形態學操作&#xff08;Morphological Operations&#xff09;源自二值圖像處理&#xff0c;主要用于分析和處理圖像中的結構元素&#xff0c;對圖像進行去噪、提取邊緣、分割等預處理步驟。OpenCV庫中提供了豐富的形態學函數&#xff0c;常見的包括&#xf…

邏輯回歸:損失和正則化技術的深入研究

邏輯回歸&#xff1a;損失和正則化技術的深入研究 引言 邏輯回歸是一種廣泛應用于分類問題的統計模型&#xff0c;尤其在機器學習領域中占據著重要的地位。盡管其名稱中包含"回歸"&#xff0c;但邏輯回歸本質上是一種分類算法。它的核心思想是在線性回歸的基礎上添…

大模型面經 | 介紹一下CLIP和BLIP

大家好,我是皮先生!! 今天給大家分享一些關于大模型面試常見的面試題,希望對大家的面試有所幫助。 往期回顧: 大模型面經 | 春招、秋招算法面試常考八股文附答案(RAG專題一) 大模型面經 | 春招、秋招算法面試常考八股文附答案(RAG專題二) 大模型面經 | 春招、秋招算法…

【MCP】第二篇:IDE革命——用MCP構建下一代智能工具鏈

【MCP】第二篇&#xff1a;IDE革命——用MCP構建下一代智能工具鏈 一、引言二、IDE集成MCP2.1 VSCode2.1.1 安裝VSCode2.1.2 安裝Cline2.1.3 配置Cline2.1.4 環境準備2.1.5 安裝MCP服務器2.1.5.1 自動安裝2.1.5.2 手動安裝 2.2 Trae CN2.2.1 安裝Trae CN2.2.2 Cline使用2.2.3 內…

【新能源科學與技術】MATALB/Simulink小白教程(一)實驗文檔【新能源電力轉換與控制仿真】

DP讀書&#xff1a;新能源科學與工程——專業課「新能源發電系統」 2025a 版本 MATLAB下面進入正題 仿真一&#xff1a;Buck 電路一、仿真目的二、仿真內容&#xff08;一&#xff09;Buck電路基本構成及工作原理&#xff08;二&#xff09;Buck電路仿真模型及元件連接&#xf…

BootStrap:首頁排版(其一)

今天我要介紹的是在BootStrap中有關于首頁排版的內容知識點&#xff0c;即&#xff08;模態框&#xff0c;選項卡&#xff09;。 模態框&#xff1a; 模態框經過了優化&#xff0c;更加靈活&#xff0c;以彈出對話框的形式出現&#xff0c;具有最小和最實用的功能集。 在運行…

Spring Data

目錄 一、Spring Data 簡介與生態概覽 什么是 Spring Data&#xff1f; Spring Data 與 Spring Data JPA 的關系 Spring Data 家族&#xff1a;JPA、MongoDB、Redis、Elasticsearch、JDBC、R2DBC…… 與 MyBatis 的本質差異&#xff08;ORM vs SQL 顯式控制&#xff09; 二…

建筑末端配電回路用電安全解決方案

一、電氣火災的嚴峻現狀 根據國家應急管理部消防救援局的數據&#xff0c;電氣火災長期占據各類火災原因之首&#xff0c;2021年占比高達50.4%。其中&#xff0c;末端配電回路因保護不足、監測手段落后&#xff0c;成為火災高發隱患點。私拉電線、線路老化、接觸不良、過載等問…

華為開發崗暑期實習筆試(2025年4月16日)

刷題小記&#xff1a; 第一題懷疑測試樣例不完整&#xff0c;貪心法不應該能夠解決該題。第二題使用0-1BFS解決單源最短路徑的問題&#xff0c;往往搭配雙端隊列實現。第三題是運用動態規劃解決最大不重疊子區間個數的問題&#xff0c;難點在于滿足3重判斷規則&#xff0c;所需…

Rust: 從內存地址信息看內存布局

內存布局其實有幾個&#xff1a;address&#xff08;地址&#xff09;、size&#xff08;大小&#xff09;、alignment&#xff08;對齊位數&#xff0c;2 的自然數次冪&#xff0c;2&#xff0c;4&#xff0c;8…&#xff09;。 今天主要從address來看內存的布局。 說明&…

每日一題算法——兩個數組的交集

兩個數組的交集 力扣題目鏈接 我的解法&#xff1a;利用數組下標。 缺點&#xff1a;當取值范圍很大時&#xff0c;浪費空間。 class Solution { public:vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {int count1[1001]{0…

c++ 互斥鎖

為練習c 線程同步&#xff0c;做了LeeCode 1114題. 按序打印&#xff1a; 給你一個類&#xff1a; public class Foo {public void first() { print("first"); }public void second() { print("second"); }public void third() { print("third"…

山東大學軟件學院創新項目實訓開發日志(20)之中醫知識問答自動生成對話標題bug修改

在原代碼中存在一個bug&#xff1a;當前對話的標題不是現有對話的用戶的第一段的前幾個字&#xff0c;而是歷史對話的第一段的前幾個字。 這是生成標題的邏輯出了錯誤&#xff1a; 當改成size()-1即可

WSL2-Ubuntu22.04下拉取Docker MongoDB鏡像并啟動

若未安裝docker可參考此教程&#xff1a;可以直接在wsl上安裝docker嗎&#xff0c;而不是安裝docker desktop&#xff1f;-CSDN博客 1. 拉取鏡像 docker pull mongo:latest 2.打開網絡加速&#xff0c;再次拉取鏡像 3.創建docker-compose.yml 進入vim編輯器后輸入i進行編輯&a…