前端编程-vue-element-admin的HelloWorld

本文介绍如何使用Vue创建后台管理系统,对比分析了vue-element-admin和vue-admin-template两个项目的优劣,适用于初学者和二次开发者。

背景

经手了很多后端子系统的项目,有一些子系统没有做cms后台,导致出现了尴尬的一刻:如果出现初始化数据的情况,必须要自己调用接口,甚至得写sql脚本来加数据。这岂不是进入了远古时代,一个不小心,数据库就会出现脏数据。。。
本博客将阐述vue-admin的后台管理的HelloWorld,侧重于应用。

npm

是什么

node package manager,node的包管理工具,可以按照类比:

  • python中的pip
  • java中的maven或者gradle
  • centos的yum
  • Ubuntu的apt
  • mac os的brew等

安装node环境

参考:https://blog.youkuaiyun.com/wangjie5540/article/details/103470356
多node环境配置

安装vue-element-admin

参考官方文档:https://panjiachen.github.io/vue-element-admin-site/zh/guide/

git clone https://github.com/PanJiaChen/vue-element-admin.git
cd vue-element-admin
npm install --registry=https://registry.npm.taobao.org
npm run dev

在这里插入图片描述
直接点击登录
在这里插入图片描述
细心的同学观察到了,这个admin的功能模块比较多,不适合新手直接去看,下面咱们找个适合新手的

安装vue-admin-template

https://github.com/PanJiaChen/vue-admin-template.git
此项目和admin项目同源,但是比较轻量,适合初学。

git clone https://github.com/PanJiaChen/vue-admin-template.git
cd vue-admin-template
npm install --registry=https://registry.npm.taobao.org
npm run dev

在这里插入图片描述
左侧导航栏少了很多

走一走代码

  • package.json,类似于maven中的pom文件,npm install将直接读取这个文件。(具体是web package的范畴)
  • man.js,总入口文件
    在这里插入图片描述
  • man.js中的绑定函数,有种mvc的思想,store代表m,router代表c,el代表v
  • vue文件是页面,在views目录中
  • js文件,编写业务逻辑

评价

  • vue-element-admin适合定制二次开发
  • vue-admin-template适合初学
### 使用 Vue 3、Vite、TypeScript 和 Pinia 构建 Element Admin 构建一个现代化的管理后台应用(Admin),可以利用 Vue 3 提供的新特性以及 Vite 带来的快速开发体验。为了实现这一目标,还需要集成 TypeScript 来增强类型安全性和代码质量,并采用状态管理模式 Pinia。 #### 初始化项目结构 首先创建一个新的 Vite 项目: ```bash npm create vite@latest my-element-admin --template vue-ts cd my-element-admin npm install ``` 安装必要的依赖包,包括 `element-plus` UI 库和 `pinia` 状态管理库: ```bash npm install element-plus pinia ``` 配置 VSCode 扩展来支持更好的开发体验,在VScode扩展里搜索并下载对应插件:Vue Language Features (Volar)和TypeScript Vue Plugin (Volar)[^1]。 #### 设置全局样式与按需加载组件 编辑 `main.ts` 文件引入 Element Plus 并设置主题颜色: ```typescript import { createApp } from &#39;vue&#39; import App from &#39;./App.vue&#39; import router from &#39;./router&#39; import store from &#39;./store&#39; // Import only what we need from Element Plus import &#39;element-plus/lib/theme-chalk/base.css&#39;; import ElButton from &#39;element-plus/lib/components/button&#39;; const app = createApp(App) app.use(store).use(router).component(&#39;ElButton&#39;, ElButton).mount(&#39;#app&#39;) ``` #### 创建基本布局页面 在 `src/views/` 下新建文件夹用于存放视图组件;定义首页 HomeView 组件作为默认展示页。 对于复杂的应用程序来说,通常会有一个侧边栏导航菜单配合顶部工具条共同组成完整的框架界面。这里可以通过组合多个基础组件完成此功能模块的设计工作。 #### 配置路由规则 通过 Vue Router 实现多级嵌套路由映射关系,从而达到单页面应用程序的效果。修改 `src/router/index.ts` 如下所示: ```typescript import { createRouter, createWebHistory } from &#39;vue-router&#39; import HomeView from &#39;../views/HomeView.vue&#39; export default createRouter({ history: createWebHistory(import.meta.env.BASE_URL), routes: [ { path: &#39;/&#39;, name: &#39;home&#39;, component: HomeView, }, // Add more route definitions here... ] }) ``` #### 添加状态管理逻辑 Pinia 是官方推荐的状态管理系统之一,它具有简洁易懂 API 设计风格。初始化 Store 后可以在任何地方访问共享数据资源而无需担心跨组件通信问题的发生。 ```typescript // src/store/index.ts import { defineStore } from &#39;pinia&#39; export const useMainStore = defineStore(&#39;main&#39;, { state: () => ({ count: 0, }), actions: { increment() { this.count++ } } }) ``` #### 定义自定义事件暴露接口 为了让父组件能够调用子组件内部的方法或属性值,可借助于 `<script setup>` 中提供的 `defineExpose()` 函数[^2]。 ```html <!-- ChildComponent.vue --> <script setup> import { ref } from &#39;vue&#39; const message = ref(&#39;Hello World!&#39;) defineExpose({ getMessage: () => message.value }) </script> <template> <!-- Component template goes here... --> </template> ``` 以上就是基于 Vue 3 + Vite + TypeScript + Pinia 技术栈搭建 Element Admin 的初步指南。当然实际生产环境中可能还会涉及到更多细节方面的考量,比如权限验证机制设计、国际化方案选型等话题值得进一步探讨研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值