Vue 3 Composition API
data:image/s3,"s3://crabby-images/1b380/1b38045e5a905e0bc6406367aa2de067a3f4bd78" alt="第四週作業展示,運用了 Vue Composition API 與 watch 功能,點擊圖片可察看成果"
前言
這裡將會記錄參加 六角學院 Vue 3 新手夏令營(活動已結束) 課程筆記 與 每日任務紀錄,第四周介紹如何使用 Composition API 與 watch 功能,並了解 Vue 2 與 Vue 3 的差異。
課堂重點
- Option API 與 Composition API 的差異
- 了解 Vue 裡面 this 的指向
- 生命週期的使用
- ref 與 reative 的差別 ( 略提 )
Option API
- 所有功能被依據程式邏輯區分
- 對初學者來說相當易學
- 缺點:商業、功能邏輯被拆分到各處
data:image/s3,"s3://crabby-images/62be9/62be996cda63444b2de3fccfa2c75ff271750960" alt="圖片取自六角學院 卡斯伯 的免費直播課程,展示 Option API 的程式邏輯"
- 藍色代表程式邏輯
- 綠色與紅色分別為同一個功能所需要用的邏輯
Option API 與 Composition API 的差異
- 而 Composition 改善其缺點,將同一個商業、功能邏輯寫在一起
data:image/s3,"s3://crabby-images/effbf/effbf77059b96420efc09cfe050dd1ad53e3df4b" alt="圖片取自六角學院 卡斯伯 的免費直播課程,展示 Composition 與 Option 的差別"
- 將分散在各處的功能邏輯集中在一起 (分散在各處的顏色集中在一起)
Composition API
- 全部整合進
setup()
內
- 高度的彈性
- 基於既有的 JS 知識開發
- 方便引入函式庫
- 所有功能邏輯都各自寫好,不會分散各地
data:image/s3,"s3://crabby-images/46451/46451ce75cfa19a359ec11304be59815ebd61f18" alt="圖片取自六角學院 卡斯伯 的免費直播課程,展示 Composition 的寫法"
Vue 的 this 指向
- Proxy 是 Vue 在做雙向綁定的重要結構
- 在 Option API 可以不知道他
- 但在 Composition API 他還蠻重要的
- 資料都會放在 Target 裡面
data:image/s3,"s3://crabby-images/9fa0a/9fa0afe05425bcd57f49526b0fc24107ad1339e3" alt="Vue 的 this 指向"
複習 ESM
CDN 連結
https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js
data:image/s3,"s3://crabby-images/82ac8/82ac8031eab567f774fc2f75c668b38dddf609bd" alt="ESM 比較能依據自己需求來引入所需的功能"
Composition API 起手式
通常都是使用 ESModule 來操作
不轉ESM也行,但在composition API使用ESM更符合模組化概念
1 2 3 4 5
| <div id="app"> {{ text }} <input type="text" v-model="text"> </div>
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <script type="module"> import { createApp } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js' const app = createApp({ setup() { const text = '卡斯伯棒棒'; return { text } } }); app.mount('#app'); </script>
|
data:image/s3,"s3://crabby-images/d60c5/d60c58fd20880d312dfa63309c2c66a04bd5fb96" alt="圖片取自六角學院 卡斯伯 的免費直播課程,卡斯伯棒棒"
Composition API 裡雙向綁定,需要引入ref
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| <script type="module"> import { createApp, ref } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js' const app = createApp({ setup() { const text = ref('卡斯伯棒棒'); return { text } } }); app.mount('#app'); </script>
|
Composition API 使用函式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| <script type="module"> import { createApp, ref } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js' const app = createApp({ setup() { const text = ref('卡斯伯棒棒'); function getText() { console.log( text ) } return { text, getText, } } }); app.mount('#app'); </script>
|
Composition API 使用生命週期
引入 onMounted
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| <script type="module"> import { createApp, ref, onMounted } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js' const app = createApp({ setup() { const text = ref('卡斯伯棒棒'); function getText() { console.log( text ) } onMounted(()=>{ getText() }) return { text, getText, } } }); app.mount('#app'); </script>
|
引入 computed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| <script type="module"> import { createApp, ref, onMounted, computed } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.2.0-beta.7/vue.esm-browser.min.js' const app = createApp({ setup() { const num = ref(1); const doubleNum = computed(()=>{ return num.value * 2 }) return { num, doubleNum, } } }); app.mount('#app'); </script>
|
data:image/s3,"s3://crabby-images/96546/9654609e64c68ab2fd4f73ff4f78aaa9054df27b" alt="圖片取自六角學院 卡斯伯 的免費直播課程,computed"
reative 與 ref 的差別
data:image/s3,"s3://crabby-images/77704/7770428d391cca60f95628d2e8dab5f524bc1cb4" alt="圖片取自六角學院 卡斯伯 的免費直播課程,ref & reative 的差別"
reative
- 非常標準的 Proxy 物件
- 限制只能放物件
- 覆蓋後會出現不可預期的錯誤
ref
- 沒有任何型別的限制
- 會依據放入的型別,而有不同的調整
- 一定要使用
.value
取值
參考資料