Upgrade Vue 2.6 To 2.7 -
- import ref, computed from '@vue/composition-api' + import ref, computed from 'vue' If using vue-loader v15:
- this.$scopedSlots.header(data) + this.$slots.header(data) Functional components using the functional: true option or <template functional> still work, but the performance benefit is minimal. Consider migrating to normal components. 4. props validation Default factory functions no longer have access to this . Use arrow functions or external helpers. New Features to Start Using Composition API (no extra import) <script> import ref, onMounted from 'vue' export default setup() const count = ref(0) onMounted(() => console.log('mounted')) return count upgrade vue 2.6 to 2.7
"dependencies": "vue": "^2.7.14"
npm install -g vetur@latest # or update via VS Code extensions If using ESLint plugin for Vue: - import ref, computed from '@vue/composition-api' + import
npm install eslint-plugin-vue@^9.0.0 --save-dev Update your ESLint config to extend: props validation Default factory functions no longer have
</script> <script setup> import ref from 'vue' const count = ref(0) </script> <template> <button @click="count++"> count </button> </template> Optional chaining and nullish coalescing <template> <div> user?.address?.city ?? 'Unknown' </div> </template> Reactivity Transform (opt-in) Enable via vue-loader config: