本文介绍了如何使用Vue3和阿里系UI组件库Ant Design Vue进行项目实战,从项目搭建、组件使用到页面设计,全面展示了Vue3的特性与Ant Design Vue的强大功能,帮助开发者构建出高质量的前端应用。
Vue.js 是一个用于构建用户界面的渐进式框架。Vue 3 是 Vue.js 的最新版本,它带来了许多改进和优化,如更快的响应速度、更小的包体积以及更好的 Typescript 支持等。
Vue 3 通过 Composition API 对 Vue 的核心概念进行了重构,使得代码更加简洁和模块化。同时,Vue 3 对模板编译进行了优化,提升了应用的加载速度和运行时性能。
在开始一个 Vue 3 项目之前,需要安装一些必要的工具和依赖。这里使用 Vue CLI 作为项目生成工具,它提供了快速搭建 Vue 项目的能力。
安装 Vue CLI
首先确保已经安装了 Node.js,接着使用 npm 或 yarn 安装 Vue CLI。
npm install -g @vue/cli
创建新项目
打开命令行工具,进入你希望存放项目的目录,然后使用 Vue CLI 创建一个新的 Vue 3 项目。
vue create my-vue3-app
进入项目目录,安装 Vue 3。
cd my-vue3-app vue add vue
项目结构
创建好的项目结构如下:
my-vue3-app/ ├── node_modules/ ├── public/ │ └── index.html ├── src/ │ ├── assets/ │ ├── components/ │ ├── App.vue │ └── main.js ├── .gitignore ├── babel.config.js ├── package.json └── README.md
其中 src
目录存放了项目的源代码,包括组件、样式、公共资源等。public
目录存放静态资源,如 HTML 文件和图标等。
运行项目
使用以下命令启动开发服务器,访问 http://localhost:8080 查看运行中的应用。
npm run serve
调试
在开发模式下,Vue CLI 会自动启用源码映射,方便调试。你可以在浏览器控制台查看具体的错误信息,并通过单击堆栈信息跳转到相关代码行。设置 Vue.config.productionTip = false
可以避免在开发过程中触发生产警告信息。
Vue.config.productionTip = false;
构建与部署
当项目开发完成,可以通过以下命令构建生产版本。
npm run build
这将生成一个 dist
目录,包含优化和压缩后的静态文件,可以直接部署到服务器。
Vue 中提供了许多内置指令来操作 DOM、绑定事件等。以下是常用的几个指令及其用法。
v-model:双向数据绑定。
<input v-model="message" placeholder="输入点啥">
v-if/v-else-if/v-else:条件渲染。
<div v-if="type === 'A'">A类型</div> <div v-else-if="type === 'B'">B类型</div> <div v-else>C类型</div>
v-for:列表渲染。
<ul> <li v-for="item in items">{{ item }}</li> </ul>
v-on:事件绑定。
<button v-on:click="increment">点击</button>
Vue 3 的 API 大部分继承自 Vue 2,但在 Composition API 的引入下,API 有了新的变化。以下是一些新的 API 用法。
ref:创建一个响应式的引用对象。
import { ref } from 'vue'; const count = ref(0);
computed:用于声明计算属性。
import { computed } from 'vue'; const fullName = computed({ get: () => `${firstName.value} ${lastName.value}`, set: (value) => { [firstName.value, lastName.value] = value.split(' '); } });
watch:监听数据变化。
import { watch } from 'vue'; watch(count, (newCount, oldCount) => { console.log(`count 变化了: ${oldCount} -> ${newCount}`); });
onMounted:在组件挂载后执行函数。
import { onMounted } from 'vue'; onMounted(() => { console.log('组件挂载完成'); });
onUnmounted:在组件卸载时执行清理操作。
import { onUnmounted } from 'vue'; let cleanup = null; onUnmounted(() => { if (cleanup) { cleanup(); } });
Composition API 提供了一种更灵活的方式来组织和重用组件逻辑。通过 setup
函数来定义组件的逻辑,并返回组件的数据。
import { ref, computed } from 'vue'; export default { setup() { const count = ref(0); const doubleCount = computed(() => count.value * 2); const increment = () => { count.value++; }; return { count, doubleCount, increment }; } };
这里的 setup
函数用于初始化组件的状态和逻辑,返回的对象将作为组件的响应式数据。
<template> <div> <p>当前值: {{ count }}</p> <p>双倍值: {{ doubleCount }}</p> <button @click="increment">增加</button> </div> </template>
Teleport
组件允许将子组件渲染到 DOM 的任何位置,甚至可以将子组件渲染到另一个 DOM 节点上。
<template> <div> <button @click="showModal = true">显示模态框</button> <teleport to="body"> <div v-if="showModal"> <p>这是模态框内容</p> <button @click="showModal = false">关闭</button> </div> </teleport> </div> </template> <script> import { ref } from 'vue'; export default { setup() { const showModal = ref(false); return { showModal }; } }; </script>
以上是一些 Vue 3 的基本概念和常用 API,通过这些知识可以搭建基础的 Vue 项目。
组件化开发是 Vue 3 的一大特色,通过将应用拆分成小的、可复用的组件,可以提高代码的可维护性和可扩展性。
组件通常定义在 src/components
目录下,每个组件都是一个独立的 Vue 组件。
// src/components/HelloWorld.vue <script> export default { name: 'HelloWorld', props: { msg: String }, setup(props) { const message = computed(() => props.msg); return { message }; } }; </script> <template> <div class="hello"> <h1>{{ message }}</h1> </div> </template>
在其他组件或模板中,你可以通过 import
导入并使用组件。
// src/App.vue <script> import HelloWorld from './components/HelloWorld.vue'; export default { components: { HelloWorld }, setup() { return {}; } }; </script> <template> <div id="app"> <HelloWorld msg="欢迎使用 Vue3" /> </div> </template>
动态组件允许在运行时根据条件选择要渲染的组件。
<template> <div> <button @click="currentComponent = 'HelloWorld'">显示 HelloWorld</button> <button @click="currentComponent = 'GoodbyeWorld'">显示 GoodbyeWorld</button> <component :is="currentComponent"></component> </div> </template> <script> import HelloWorld from './components/HelloWorld.vue'; import GoodbyeWorld from './components/GoodbyeWorld.vue'; export default { components: { HelloWorld, GoodbyeWorld }, setup() { const currentComponent = ref('HelloWorld'); return { currentComponent }; } }; </script>
Vue Router 是 Vue 官方的路由库,它允许你根据 URL 路径来切换视图组件。首先需要安装 Vue Router。
npm install vue-router@next
然后定义路由配置。
// src/router.js import { createRouter, createWebHistory } from 'vue-router'; import Home from '../views/Home.vue'; import About from '../views/About.vue'; const routes = [ { path: '/', component: Home }, { path: '/about', component: About } ]; const router = createRouter({ history: createWebHistory(), routes }); export default router;
接着在主应用文件中引入并使用路由。
// src/main.js import { createApp } from 'vue'; import App from './App.vue'; import router from './router'; createApp(App).use(router).mount('#app');
Vuex 是 Vue 的状态管理库,可以用于构建复杂的前端应用状态。首先安装 Vuex。
npm install vuex@next
然后创建一个 Vuex store。
// src/store/index.js import { createStore } from 'vuex'; export default createStore({ state: { count: 0 }, mutations: { increment(state) { state.count++; } }, actions: { increment({ commit }) { commit('increment'); } } });
接着在主应用文件中引入并使用 Vuex。
// src/main.js import { createApp } from 'vue'; import App from './App.vue'; import store from './store'; createApp(App).use(store).mount('#app');
通过以上步骤,你可以使用 Vue Router 和 Vuex 来管理你的 Vue 3 应用的路由和状态。
Vue 3 中的生命周期钩子用于在组件生命周期的不同阶段执行特定的操作。
import { onMounted, onUnmounted } from 'vue'; export default { setup() { onMounted(() => { console.log('组件挂载'); }); onUnmounted(() => { console.log('组件卸载'); }); return {}; } };
自定义指令可以让你在 Vue 的应用中扩展 HTML 元素的功能。
import { createApp } from 'vue'; const app = createApp({}); app.directive('focus', { mounted(el) { el.focus(); } }); app.mount('#app');
以上是 Vue 3 的一些基本概念和常用功能,通过这些内容可以为后续的项目开发打下坚实的基础。
Ant Design Vue 是 Ant Design 的 Vue 实现,它提供了丰富的组件库,可用于构建 Web 应用的用户界面。Ant Design Vue 组件库遵循 Material Design 和 Ant Design 的设计语言,可以快速构建美观、易用的界面。
首先,确保已经安装了 Vue CLI 和 Vue 3,然后通过 npm 安装 Ant Design Vue。
npm install ant-design-vue
安装成功后,在主应用文件中引入并使用 Ant Design Vue。
import { createApp } from 'vue'; import App from './App.vue'; import Antd from 'ant-design-vue'; import 'ant-design-vue/dist/antd.css'; createApp(App).use(Antd).mount('#app');
这里需要导入 Antd
模块,并将其链接到 Vue 应用中。同时要引入 Ant Design Vue 的样式文件。
以下是一些常用的 Ant Design Vue 组件示例,包括按钮、图标、布局等。
<template> <a-button type="primary">按钮</a-button> <a-icon type="smile" /> <a-layout> <a-layout-header>头部</a-layout-header> <a-layout-content>内容区域</a-layout-content> <a-layout-footer>底部</a-layout-footer> </a-layout> </template> <script> export default { setup() { return {}; } }; </script>
通过 a-button
、a-icon
和 a-layout
组件可以创建基本的按钮、图标和布局结构。
Ant Design Vue 组件也支持动态组件和插槽。
<template> <a-button v-if="isPrimary" type="primary">主要按钮</a-button> <a-button v-else type="secondary">次要按钮</a-button> </template> <script> import { ref } from 'vue'; export default { setup() { const isPrimary = ref(true); return { isPrimary }; } }; </script>
或者使用插槽来自定义组件内容。
<template> <a-card title="卡片标题"> <template #default> <p>这是卡片内容。</p> </template> </a-card> </template> <script> export default { setup() { return {}; } }; </script>
这些组件的使用可以让你快速构建出美观、功能丰富的 Web 页面。
结合 Vue Router 和 Ant Design Vue 组件可以实现导航和路由切换。
<template> <a-layout> <a-layout-header> <a-menu mode="horizontal"> <a-menu-item> <router-link to="/">主页</router-link> </a-menu-item> <a-menu-item> <router-link to="/about">关于</router-link> </a-menu-item> </a-menu> </a-layout-header> <a-layout-content> <router-view /> </a-layout-content> </a-layout> </template>
通过 a-menu
和 router-link
组件,可以实现基于 URL 的导航。
Ant Design Vue 提供了强大的表单和表格组件,用于数据的输入和展示。
<template> <a-form :model="formState" :label-col="{ span: 8 }" :wrapper-col="{ span: 16 }"> <a-form-item label="用户名"> <a-input v-model="formState.username" /> </a-form-item> <a-form-item :wrapper-col="{ offset: 8, span: 16 }"> <a-button type="primary">提交</a-button> </a-form-item> </a-form> <a-table :columns="columns" :data-source="data" /> </template> <script> import { ref } from 'vue'; export default { setup() { const formState = ref({ username: '' }); const columns = [ { title: '姓名', dataIndex: 'name', key: 'name' }, { title: '年龄', dataIndex: 'age', key: 'age' }, { title: '地址', dataIndex: 'address', key: 'address' } ]; const data = [ { key: '1', name: '张三', age: 32, address: '广州市' }, { key: '2', name: '李四', age: 42, address: '武汉市' } ]; return { formState, columns, data }; } }; </script>
通过 a-form
和 a-table
组件,可以创建具有复杂功能的表单和表格。
通过以上这些示例可以快速搭建出一个具有 UI 组件的 Vue 3 项目。
在开发一个 Vue 3 项目前,需要先进行详细的项目需求分析。需求分析帮助我们明确项目目标、功能、界面设计等关键信息。
创建一个新的 Vue 3 项目,并设置项目的基本结构。
npm create vite@latest my-ecommerce-app --template vue cd my-ecommerce-app npm install ant-design-vue npm install vue-router npm install axios
安装完成后,项目结构可能如下:
my-ecommerce-app/ ├── node_modules/ ├── public/ │ └── index.html ├── src/ │ ├── assets/ │ ├── components/ │ ├── views/ │ │ ├── Home.vue │ │ ├── Login.vue │ │ ├── Register.vue │ │ ├── ProductDetail.vue │ │ ├── Cart.vue │ │ ├── Order.vue │ │ ├── Checkout.vue │ └── App.vue ├── .gitignore ├── babel.config.js ├── package.json └── README.md
在 src/main.js
中引入并使用 Ant Design Vue 和 Vue Router。
import { createApp } from 'vue'; import App from './App.vue'; import Antd from 'ant-design-vue'; import 'ant-design-vue/dist/antd.css'; import router from './router'; createApp(App).use(Antd).use(router).mount('#app');
在 src/router.js
中配置基本的路由。
import { createRouter, createWebHistory } from 'vue-router'; import Home from '../views/Home.vue'; import Login from '../views/Login.vue'; import Register from '../views/Register.vue'; import ProductDetail from '../views/ProductDetail.vue'; import Cart from '../views/Cart.vue'; import Order from '../views/Order.vue'; import Checkout from '../views/Checkout.vue'; const routes = [ { path: '/', component: Home }, { path: '/login', component: Login }, { path: '/register', component: Register }, { path: '/product/:id', component: ProductDetail }, { path: '/cart', component: Cart }, { path: '/order', component: Order }, { path: '/checkout', component: Checkout } ]; const router = createRouter({ history: createWebHistory(), routes }); export default router;
在 src/components
目录下创建一些常用的组件,例如 Navbar.vue
、Footer.vue
等。
<!-- src/components/Navbar.vue --> <template> <a-layout-header style="background: #fff; padding: 0 16px;"> <a-menu mode="horizontal"> <a-menu-item> <router-link to="/">首页</router-link> </a-menu-item> <a-menu-item> <router-link to="/login">登录</router-link> </a-menu-item> <a-menu-item> <router-link to="/register">注册</router-link> </a-menu-item> </a-menu> </a-layout-header> </template>
接下来只需根据项目需求逐步构建各个页面和功能模块。
在 src/assets
目录下存放一些公共的资源文件,如图片、字体等。
src/ ├── assets/ │ ├── images/ │ └── fonts/
在构建项目时,需要确保 Ant Design Vue 的样式和组件已经被正确引入和使用。
在 src/main.js
中引入并使用 Ant Design Vue。
import { createApp } from 'vue'; import App from './App.vue'; import Antd from 'ant-design-vue'; import 'ant-design-vue/dist/antd.css'; createApp(App).use(Antd).mount('#app');
为了展示如何使用 Ant Design Vue 组件,可以创建一个简单的登录页面。
<!-- src/views/Login.vue --> <template> <a-card title="登录表单"> <a-form :model="formState" :label-col="{ span: 8 }" :wrapper-col="{ span: 16 }"> <a-form-item label="用户名"> <a-input v-model="formState.username" /> </a-form-item> <a-form-item label="密码"> <a-input v-model="formState.password" /> </a-form-item> <a-form-item :wrapper-col="{ offset: 8, span: 16 }"> <a-button type="primary" @click="login">登录</a-button> </a-form-item> </a-form> </a-card> </template> <script> import { ref } from 'vue'; export default { setup() { const formState = ref({ username: '', password: '' }); function login() { console.log('登录:', formState.value); } return { formState, login }; } }; </script>
通过以上步骤,可以将 Ant Design Vue 的组件引入并应用到项目中。
可以创建一些基础的页面和组件,例如主页、登录页面、注册页面等。
<!-- src/views/Home.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="欢迎使用电商网站"> <p>这里是首页内容。</p> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; export default { components: { Navbar, Footer } }; </script>
通过这些基础页面和组件,可以搭建出一个初步的电商网站前端框架。
在项目开发阶段,需要根据需求分析设计各个页面,并通过组件化的方式进行开发。
设计一些关键页面的结构:
将页面拆分成小的组件,每个组件具有独立的功能,可以复用。
<!-- src/components/ProductCard.vue --> <template> <a-card :title="product.name"> <a-image :class="lazyload" src="" data-original="product.image" /> <p>{{ product.description }}</p> <a-button type="primary" @click="addToCart">加入购物车</a-button> </a-card> </template> <script> import { ref } from 'vue'; export default { props: { product: Object }, setup(props) { const addToCart = () => { console.log('添加到购物车:', props.product); }; return { addToCart }; } }; </script>
使用 Vue Router 实现页面之间的导航。
import { createRouter, createWebHistory } from 'vue-router'; import Home from '../views/Home.vue'; import Login from '../views/Login.vue'; import Register from '../views/Register.vue'; import ProductDetail from '../views/ProductDetail.vue'; import Cart from '../views/Cart.vue'; import Order from '../views/Order.vue'; import Checkout from '../views/Checkout.vue'; const routes = [ { path: '/', component: Home }, { path: '/login', component: Login }, { path: '/register', component: Register }, { path: '/product/:id', component: ProductDetail }, { path: '/cart', component: Cart }, { path: '/order', component: Order }, { path: '/checkout', component: Checkout } ]; const router = createRouter({ history: createWebHistory(), routes }); export default router;
通过动态数据绑定和事件处理实现页面的功能。
<!-- src/views/Home.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="新品推荐"> <a-row :gutter="16"> <a-col :span="6" v-for="product in products" :key="product.id"> <ProductCard :product="product" /> </a-col> </a-row> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; import ProductCard from '../components/ProductCard.vue'; import { ref } from 'vue'; export default { components: { Navbar, Footer, ProductCard }, setup() { const products = ref([ { id: 1, name: '商品1', description: '这是商品1的描述', image: 'product1.jpg' }, { id: 2, name: '商品2', description: '这是商品2的描述', image: 'product2.jpg' } ]); return { products }; } }; </script>
在登录、注册、订单管理等页面中使用表单和表格组件。
<!-- src/views/Cart.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="购物车"> <a-table :columns="columns" :data-source="cartItems" /> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; import { ref } from 'vue'; export default { components: { Navbar, Footer }, setup() { const columns = [ { title: '商品名称', dataIndex: 'name' }, { title: '数量', dataIndex: 'quantity' }, { title: '总价', dataIndex: 'totalPrice' } ]; const cartItems = ref([ { name: '商品1', quantity: 2, totalPrice: 100 }, { name: '商品2', quantity: 1, totalPrice: 50 } ]); return { columns, cartItems }; } }; </script>
通过这些页面设计和组件化开发,可以实现电商网站的基本功能。
在项目中,表单和表格组件的应用非常广泛,用于数据的输入和展示。
设计一个商品详情页,展示商品信息并允许用户评论。
<!-- src/views/ProductDetail.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="商品详情"> <a-row :gutter="16"> <a-col :span="12"> <a-image :class="lazyload" src="" data-original="product.image" /> </a-col> <a-col :span="12"> <p>{{ product.description }}</p> <a-button type="primary" @click="addToCart">加入购物车</a-button> </a-col> </a-row> <a-divider /> <a-form :model="formState" :label-col="{ span: 8 }" :wrapper-col="{ span: 16 }"> <a-form-item label="评论"> <a-form-item> <a-input v-model="formState.comment" /> </a-form-item> <a-form-item :wrapper-col="{ offset: 8, span: 16 }"> <a-button type="primary" @click="submitComment">提交评论</a-button> </a-form-item> </a-form-item> </a-form> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; import { ref } from 'vue'; export default { components: { Navbar, Footer }, setup() { const product = ref({ name: '商品1', description: '这是商品1的描述', image: 'product1.jpg' }); const formState = ref({ comment: '' }); const addToCart = () => { console.log('加入购物车:', product.value); }; const submitComment = () => { console.log('评论提交', formState.value.comment); }; return { product, formState, addToCart, submitComment }; } }; </script>
设计一个订单管理页面,展示用户的订单列表。
<!-- src/views/Order.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="订单列表"> <a-table :columns="columns" :data-source="orders" /> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; import { ref } from 'vue'; export default { components: { Navbar, Footer }, setup() { const columns = [ { title: '订单号', dataIndex: 'orderNumber' }, { title: '商品名称', dataIndex: 'productName' }, { title: '数量', dataIndex: 'quantity' }, { title: '总价', dataIndex: 'totalPrice' } ]; const orders = ref([ { orderNumber: '12345', productName: '商品1', quantity: 2, totalPrice: 100 }, { orderNumber: '67890', productName: '商品2', quantity: 1, totalPrice: 50 } ]); return { columns, orders }; } }; </script>
通过这些表单和表格组件的设计和实现,可以满足电商网站数据输入和展示的需求。
在实际开发过程中,动态数据绑定和事件处理是实现页面交互的关键。
在组件中绑定动态数据,实现数据的双向绑定。
<!-- src/components/ProductCard.vue --> <template> <a-card :title="product.name"> <a-image :class="lazyload" src="" data-original="product.image" /> <p>{{ product.description }}</p> <a-button type="primary" @click="addToCart">加入购物车</a-button> </a-card> </template> <script> import { ref } from 'vue'; export default { props: { product: Object }, setup(props) { const addToCart = () => { console.log('添加到购物车:', props.product); }; return { addToCart }; } }; </script>
在组件中绑定事件处理器,响应用户操作。
<!-- src/views/Cart.vue --> <template> <a-layout> <a-layout-header> <Navbar /> </a-layout-header> <a-layout-content> <a-card title="购物车"> <a-table :columns="columns" :data-source="cartItems" /> <a-button type="primary" @click="checkOut">结账</a-button> </a-card> </a-layout-content> <a-layout-footer> <Footer /> </a-layout-footer> </a-layout> </template> <script> import Navbar from '../components/Navbar.vue'; import Footer from '../components/Footer.vue'; import { ref } from 'vue'; export default { components: { Navbar, Footer }, setup() { const columns = [ { title: '商品名称', dataIndex: 'name' }, { title: '数量', dataIndex: 'quantity' }, { title: '总价', dataIndex: 'totalPrice' } ]; const cartItems = ref([ { name: '商品1', quantity: 2, totalPrice: 100 }, { name: '商品2', quantity: 1, totalPrice: 50 } ]); const checkOut = () => { console.log('结账'); }; return { columns, cartItems, checkOut }; } }; </script>
通过以上实例,可以实现电商网站页面的动态数据绑定和事件处理。
在开发过程中,可能会遇到一些常见的问题。
解决办法:
解决办法:
解决办法:
ref
或 reactive
定义响应式数据。watch
或 computed
监听数据变化。在开发过程中,需要关注应用的性能,以提升用户体验。
webpack
对静态资源进行压缩。import
动态导入的方式,按需加载模块。npm run build
构建生产版本的静态文件。通过以上各种方法可以解决项目开发中的常见问题,并提升应用的性能和用户体验。
在本教程中,我们从创建 Vue 3 项目开始,通过引入和使用 Ant Design Vue,构建了一个电商网站的前端页面。通过组件化开发,实现了用户登录、注册、商品浏览、购物车管理等功能。
建议继续深入学习 Vue 的高级特性,例如 Composition API 和 TypeScript 支持。同时,可以探索更多前端框架和库,比如 Next.js、React 和 Angular,以拓展技术栈和视野。
在开发过程中,可以参考一些社区资源和官方文档,获取最新的技术信息和最佳实践。
通过这些资源,可以进一步提升技能,并参与到社区的交流和分享中。
以上内容总结了 Vue 3 项目开发的基本流程和应用,希望能帮助你构建出高质量的前端应用。