Composition API
Composable component with
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2bbcf/2bbcf2b1a9396a259fa568fa044803893d7cc983" alt=""
data:image/s3,"s3://crabby-images/80f84/80f840f0e0177d66c884566ac63caf390dd8ec98" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
Vue Status
data:image/s3,"s3://crabby-images/ee895/ee895fa38d77b4638ffb5aec3b90d54033e40a78" alt=""
data:image/s3,"s3://crabby-images/19a58/19a584a2fdff1eda87e32970c71772e955d77331" alt=""
data:image/s3,"s3://crabby-images/a6c72/a6c7282a0f1306491c5e64c1cb8bfdf1167db704" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
Options-based
Lightweight
DX enhancement
Scalable & Performant
data:image/s3,"s3://crabby-images/80f84/80f840f0e0177d66c884566ac63caf390dd8ec98" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
3.x
Functional & Options-based
Lighter-weight
DX enhancement
Scalable & Performant
data:image/s3,"s3://crabby-images/80f84/80f840f0e0177d66c884566ac63caf390dd8ec98" alt=""
Better TypeScript support
Better tree-shakable
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
3.x
data:image/s3,"s3://crabby-images/80f84/80f840f0e0177d66c884566ac63caf390dd8ec98" alt=""
data:image/s3,"s3://crabby-images/1a234/1a2346fdbec0fa944b5ee92ea8dad15dc50b3832" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
A set of low-level APIs to use Vue features outside of Vue component
Composition API
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
Another way to write complex component
Composition API
Better reusable code quality
Solve the problems that mixins can't solve
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
ref()
defineComponent()
h()
reactive() / watchEffect()
provide() / inject()
computed() / watch()
lifecycle hooks (using with setup)
export default {
name: 'MyComp',
provide: {},
inject: {},
data() { return { count: 1 } },
computed: { /*...*/ },
watch: { /*...*/ },
methods: {},
mounted() {}
render(h) { return h() }
}
import {
defineComponent,
h, onMounted,
ref, computed, watch,
provide, inject
} from 'vue'
export default defineComponent({
name: 'MyComp',
methods: {},
setup(props, context) {
const name = ref('maya')
onMounted(() => { /*...*/ })
provide('someProvider', {})
const injectValue = inject('someInjector')
watch(name, (newValue) => {})
const msg = computed(
() => `hi ${name.value}`
)
return () => h(
'div',
[name, injectValue, msg]
)
},
})
readonly()
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
Immutable state
readonly()
watchEffect( onInvalidate => {}, options )
Apply side-effect based on reactive state
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
beforeCreate
created
beforeMount
mounted
beforeUpdate
Lifecycle Hooks with setup()
updated
beforeDestroy
destroyed
errorCaptured
Vue 2.x
beforeCreate
created
beforeMount
mounted
beforeUpdate
updated
beforeUnmount
unmounted
errorCaptured
renderTracked
renderTriggered
Vue 3.x
onBeforeMount
onBeforeUpdate
onMounted
onUpdated
onUnmounted
onBeforeUnmount
onErrorCaptured
onRenderTracked
onRenderTriggered
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/59514/595149ce7b43420fe8c1b6f90fa86040eed67413" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
What's next?
Use Vite instead of Webpack
Migration tools in Q1 (hopefully) for simple components
Vuex 5 (haven't we all upgraded to Vuex 4 😆 ?)
Migration to Vue Router
Ditch IE11 finally!
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
console.log(Maya)
data:image/s3,"s3://crabby-images/8db04/8db04e3302f0ee5912a3733d034307f9f3a3c2eb" alt=""
Senior Frontend Developer
Core maintainer of StorefrontUI
NuxtJS Ambassador
Everything about Frontend/Web
data:image/s3,"s3://crabby-images/0d230/0d2300a60bccbf75466e7557cea68000cbce9953" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
THANK YOU!
data:image/s3,"s3://crabby-images/2d6ba/2d6ba32d01126078b35688381cde685c0449ad86" alt=""
Compose component with Composition API
By Maya Shavin
Compose component with Composition API
- 1,213