vuejs3.0 从入门到精通——Vue3代码风格
Vue2、Vue3代码风格
一、导入方式
Vue2 使用require
导入方式,例如:
1 | var Vue = require( 'vue' ) |
Vue3 支持 ES6 的 import 方法,例如:
1 | import { createApp } from 'vue' |
二、组件定义
Vue2 使用Vue.component
全局注册组件,例如:
1 2 3 | Vue.component( 'my-component' , { // options... }) |
Vue3 推荐使用setup
方法来定义组件,例如:
1 2 3 4 5 6 7 8 9 10 11 | import { ref, onMounted } from 'vue' export default { setup() { const someData = ref( 'Hello World' ) onMounted(() => { console.log(someData.value) // 'Hello World' }) return { someData } } } |
三、生命周期钩子
Vue2 使用created
,mounted
,updated
,destroyed
等生命周期钩子,例如:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | export default { created() { console.log( 'Component created' ) }, mounted() { console.log( 'Component mounted' ) }, updated() { console.log( 'Component updated' ) }, destroyed() { console.log( 'Component destroyed' ) } } |
Vue 3 使用onMounted
,onUpdated
,onUnmounted
等生命周期钩子,例如:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | export default { setup() { onMounted(() => { console.log( 'Component mounted' ) }) onUpdated(() => { console.log( 'Component updated' ) }) onUnmounted(() => { console.log( 'Component destroyed' ) }) return {} } } |
四、Vue3.x 升级做了向下兼容(Vue2.x)
4.1 Vue3 做了向下兼容, 也支持 Vue2 的写法(有些不行)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <template> 首页 Home.vue <h1>{{ str }}</h1> <News></News> </template> <script lang= "ts" > import News from '@/components/News.vue' export default { data() { return { str: "你好xxxx" } }, components: { News } } </script> |
4.2、Vue3 + Vue2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <template> 首页 Home.vue <h1>{{ str }}</h1> <News></News> </template> <script lang= "ts" > import News from '@/components/News.vue' export default { setup() { let str = '首页' return { str } }, components: { News } } </script> |
4.3、纯 Vue3、setup 语法糖的写法
1 2 3 4 5 6 7 8 9 10 11 | <template> 首页 Home.vue <h1>{{ str }}</h1> <News></News> </template> <script setup lang= "ts" > import News from '@/components/News.vue' let str = '首页' ; </script> |
分类:
Vue3专题精讲
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具