封装UI组件库系列第一篇·搭建项目
前言
在前端开发中,大家可能已经用过各种各样的UI组件库了,现在市面上热门的有Element-ui、Ant Design等等,这些即插即用的组件库确实大大提升了开发效率,避免了很多的重复劳动,但这些组件库再怎么完善,又怎么能满足得了我们可爱的产品经理呢?所以工作中难免会需要开发公司内部的UI组件库,或者基于已有组件库进行二开。
【封装UI组件库系列】 文章,**将从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》使用自己封装的组件库。**技术方面使用的是Vue3 + Vite + Sass 来完成一个模仿Element Plus的组件库。最终完成效果如下:
data:image/s3,"s3://crabby-images/eccdb/eccdba5f8b9cc41cb199cefee692aecb4ed17351" alt=""
data:image/s3,"s3://crabby-images/08e72/08e72ab9148ec83163df58459daa3876155fc97a" alt=""
🌟搭建项目
创建工程
组件库使用Vue3+Vite搭建,所以第一步先创建工程:
javascript
pnpm create vue@latest
我使用的是pnpm包管理工具,这个根据个人情况来就行npm、yarn等都可 。
data:image/s3,"s3://crabby-images/8ac8c/8ac8c4a232a77b776ee00940d2b9997e14761f9e" alt=""
项目创建完成后 pnpm i 安装依赖,pnpm dev启动项目:
data:image/s3,"s3://crabby-images/d1bfd/d1bfd0ab5532ce2cc6cf66b85d1e36c9aab62a22" alt=""
基本结构
接下来我们将以下图为最终效果来一步步实现:
data:image/s3,"s3://crabby-images/5ed41/5ed4175671a47fe5b75987ec12200975b61ada6e" alt=""
1.创建8个组件展示页面:
2.配置路由文件router/index.js
javascript
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/91d31/91d315cb84f37a93d5ab75646941a111d3807600" alt=""
样式会使用sass,所以需要pnpm add -D sass
data:image/s3,"s3://crabby-images/88fbd/88fbd33e5003745f35f39f3cc3f5427f7f9744a9" alt=""
.active 其实就是选中样式,上面在路由文件配置的linkActiveClass: 'active' ,就是使用的这里的样式。
这时启动项目会发现如下图:
data:image/s3,"s3://crabby-images/0dbb9/0dbb9ad823af2c89b613e98ad8df9224f7a17f06" alt=""
这是因为在main.js中引用了默认样式import './assets/main.css'
data:image/s3,"s3://crabby-images/fb672/fb672128a4ae65f2a9845a3b0df4c9938e3c792f" alt=""
打开main.css文件,删去我们用不到的样式,剩下如图:
data:image/s3,"s3://crabby-images/0945d/0945d4cd69a5457f709471885ebc3f92caef0e71" alt=""
再打开项目得到如下图效果,那么项目的基本布局就完成了。
data:image/s3,"s3://crabby-images/4d7a6/4d7a660b657f030708b361e103ea3a342639b705" alt=""
本篇将项目以及页面搭建好后,下一篇就是使用Sass语法模仿Element Plus 创建主题色彩,以及重置样式。
data:image/s3,"s3://crabby-images/e877b/e877be7f4577af5e886223e78656ae8516acad09" alt=""
🌟总结
【封装UI组件库系列】文章会持续更新,将带着大家从0开始--》搭建项目--》封装八大经典功能组件--》打包组件库--》将组件库发布至npm--》最后使用自己封装的组件库。如果文中出现有瑕疵的地方各位通过评论或者私信联系我,我们一起进步!该系列文章建议从第一篇开始看,系列专栏地址:从零开始封装UI组件库完整篇
data:image/s3,"s3://crabby-images/17325/173259f81ad1b8ba1c31a2eb07e150c9b3918f5f" alt=""