vue3在構建時使用魔法糖語法時defineProps和defineEmits的注意事項小結
1.vue2和vue3區(qū)別
1.1 vue3中vue是一個對象,可以使用按需導入
import {createApp} from 'vue ’
1.2 導入區(qū)別
vue2中使用的vue-router3.0導入的是構造函數 new VueRouter()
vue3中使用的vue-router4.0導入的是對象 createRouter()
1.3 語法
vue2語法在vue3中都可以使用,除了過濾器并不能使用
2. vue3腳手架
腳手架中的路由有三種模式:歷史模式history、哈希模式hash、抽象模式abstract
2.1 腳手架配置
vue create projectname------Manually select features--------Babel(js編譯器)、Router、Vuex、CSS Pre-processors(css預處理器)
接下來介紹vue3在構建時,使用魔法糖語法時defineProps和defineEmits的注意事項、
在 Vue 3.2+ 版本中,可以使用 <script setup> 替代傳統的 script標簽來編寫組件,它提供了更簡潔的語法來編寫 Composition API 代碼。
在 <script setup> 中,使用 defineProps 和 defineEmits時需要注意:
- 如果顯式地導入defineProps時,在編譯時會提示以下wanning
<script steup>
import { defineProps } from 'vue';
...
</script>開發(fā)環(huán)境編譯時會提示
[@vue/compiler-sfc] `defineProps` is a compiler macro and no longer needs to be imported.
原因是在 <script setup>中,defineProps 和 defineEmits 現在是編譯器宏(compiler macros),這意味著你不再需要顯式地從 'vue' 包中導入它們。這些宏在 <script setup> 的上下文中是自動可用的。
- 如果不顯式導出有可能提示以下錯誤
ERROR Failed to compile with 1 error [eslint] 40:1 error 'defineProps' is not defined no-undef
要解決以上問題,既不重復導入又不在編譯時提示warning,可以在package.json里添加一行配置:
package.json
...
"eslintConfig": {
"root": true,
"env": {
"node": true,
"vue/setup-compiler-macros": true #添加這行配置
},
...到此這篇關于vue3在構建時使用魔法糖語法時defineProps和defineEmits的注意事項小結的文章就介紹到這了,更多相關vue3 defineProps和defineEmits內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一文帶你深入理解Vue3中Composition API的使用
Composition API 是 Vue 3 中的一項強大功能,它改進了代碼組織和重用,使得構建組件更加靈活和可維護,本文我們將深入探討 Composition API 的各個方面,希望對大家有所幫助2023-10-10
基于vue實現滾動條滾動到指定位置對應位置數字進行tween特效
這篇文章主要介紹了基于vue實現滾動條滾動到指定位置對應位置數字進行tween特效,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04

