您好,登錄后才能下訂單哦!
這篇文章主要介紹“Vue3.x項目開發的常用知識點有哪些”,在日常操作中,相信很多人在Vue3.x項目開發的常用知識點有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Vue3.x項目開發的常用知識點有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
PS:以下知識點都是基于 vue3.x + typescript + element-plus + setup語法糖 使用的。
const props = defineProps({ visible: { type: Boolean, default: false } }) console.log(props.visible)
[warning] 注意:defineProps 不用從vue引入,setup 語法糖環境會自動識別
在 el-table-column 中使用 formatter 簡寫
<el-table-column label="時間" prop="createTime" :formatter="(...args: any[]) => formatTime(args[2])" />
子組件:
<script setup lang="ts"> const props = defineProps({ visible: { type: Boolean, default: false } }) const emit = defineEmits(['closeILdialog']) // 注冊觸發器,defineEmits不用從vue引入,setup語法糖環境會自動識別 function onDialogClose() { emit('closeILdialog') // 觸發 } </script> <template> <el-dialog v-model="visible" width="900px" @close="onDialogClose" title="日志" :close-on-click-modal="false" > </el-dialog> </template>
父組件:
<script setup lang="ts"> let ILdialog = reactive({ visible: false }) function closeILdialog() { ILdialog.visible = false } </script> <template> <instruct-log :visible="ILdialog.visible" @closeILdialog="closeILdialog"></instruct-log> </template>
const props = defineProps({ visible: { type: Boolean, default: false } }) // 監聽visible watch(() => props.visible, (newV) => { if(newV) { // ... } })
局部指令:
<script setup lang="ts"> const vFoo = { mounted(el: any, binding: any) { console.log(binding.value) // 123 } } </script> <template> <div v-foo="123" v-auth="true"></div> </template>
[warning] 注意:局部指令定義需要 v 開頭,如:vFoo,這樣才能識別到 v-foo 指令
全局指令:
const app = createApp(App) // 權限指令 app.directive('auth', { mounted(el: any, binding: any) { if(!binding.value) { el.parentNode.removeChild(el) } } })
到此,關于“Vue3.x項目開發的常用知識點有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。