封装UI组件库系列第一篇·搭建项目
前言
🌟搭建项目
创建工程
基本结构
1.创建8个组件展示页面
2.配置路由文件router/index.js
3.页面布局
🌟总结
前言
在前端开发中,大家可能已经用过各种各样的UI组件库了,现在市面上热门的有Element-ui、Ant Design等等,这些即插即用的组件库确实大大提升了开发效率,避免了很多的重复劳动,但这些组件库再怎么完善,又怎么能满足得了我们可爱的产品经理呢
?所以工作中难免会需要开发公司内部的UI组件库,或者基于已有组件库进行二开。
【封装UI组件库系列】文章,将从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》使用自己封装的组件库。技术方面使用的是Vue3 + Vite + Sass 来完成一个模仿Element Plus的组件库。最终完成效果如下:
data:image/s3,"s3://crabby-images/2bdbf/2bdbf6c0bb3b2760cdfbeddf1bef436d9b04180b" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
🌟搭建项目 创建工程
组件库使用Vue3+Vite搭建,所以第一步先创建工程:
pnpm create vue@latest
我使用的是pnpm包管理工具,这个根据个人情况来就行npm、yarn等都可 。
data:image/s3,"s3://crabby-images/d8c20/d8c2028b30d2f1b64dddca526bb027174c9422b0" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
项目创建完成后 pnpm i安装依赖,pnpm dev启动项目:
data:image/s3,"s3://crabby-images/e926c/e926cca7f5c381bd5c242784cadcec8b6767caec" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
基本结构
接下来我们将以下图为最终效果来一步步实现:
data:image/s3,"s3://crabby-images/9edd0/9edd00a6e195cb020519eca42e01bc64df55fd35" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
1.创建8个组件展示页面:
data:image/s3,"s3://crabby-images/a6ccf/a6ccf0f6dbb163be094e2840422c3ebc01c60820" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
2.配置路由文件router/index.js import { createRouter, createWebHistory } from 'vue-router' import IconView from '../views/IconView.vue' const router = createRouter({ history: createWebHistory(import.meta.env.BASE_URL), routes: [ { path: '/', name: 'icon', component: IconView }, { path: '/button', name: 'button', component: () => import('../views/ButtonView.vue') }, { path: '/card', name: 'card', component: () => import('../views/CardView.vue') }, { path: '/dialog', name: 'dialog', component: () => import('../views/DialogView.vue') }, { path: '/collapse', name: 'collapse', component: () => import('../views/CollapseView.vue') }, { path: '/pager', name: 'pager', component: () => import('../views/PagerView.vue') }, { path: '/tooltip', name: 'tooltip', component: () => import('../views/TooltipView.vue') }, { path: '/dropdown', name: 'dropdown', component: () => import('../views/DropdownView.vue') } ], linkActiveClass: 'active' }) export default router 3.页面布局
在App.vue中将页面基本布局完善
data:image/s3,"s3://crabby-images/bc0d2/bc0d2f63dbc8f8477a0f6fa650fa4f0668b11d5a" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
样式会使用sass,所以需要pnpm add -D sass
data:image/s3,"s3://crabby-images/80317/80317f2021cd510c4456b14cb740ab584f7e23f5" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
.active其实就是选中样式,上面在路由文件配置的linkActiveClass: 'active',就是使用的这里的样式。
这时启动项目会发现如下图:
data:image/s3,"s3://crabby-images/4a8b4/4a8b47905be95014e39c74161e0dcdef7761f6ac" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
这是因为在main.js中引用了默认样式import './assets/main.css'
data:image/s3,"s3://crabby-images/f8a00/f8a000982bd8179e830af05430e0068e822b6a7d" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
打开main.css文件,删去我们用不到的样式,剩下如图:
data:image/s3,"s3://crabby-images/d96ca/d96ca112a0f0277f167e5f54a57e04f67c749229" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
再打开项目得到如下图效果,那么项目的基本布局就完成了。
data:image/s3,"s3://crabby-images/68ee7/68ee73fdda03e99845a3aba57e8f81bc675b8b10" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
本篇将项目以及页面搭建好后,下一篇就是使用Sass语法模仿Element Plus 创建主题色彩,以及重置样式。
data:image/s3,"s3://crabby-images/de266/de2669a25cd28efccf5196116bffc60ff567d94c" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"
🌟总结
【封装UI组件库系列】文章会持续更新,将带着大家从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》最后使用自己封装的组件库。如果文中出现有瑕疵的地方各位通过评论或者私信联系我,我们一起进步!该系列文章建议从第一篇开始看,系列专栏地址:从零开始封装UI组件库完整篇
data:image/s3,"s3://crabby-images/e780c/e780ccee713a2bb43b41b339a9d6b2341f5053ab" alt="【封装UI组件库系列】搭建项目及准备工作 【封装UI组件库系列】搭建项目及准备工作"