1.搭建项目
`npm create vue@latest`
```plaintext
✔ Project name: … vue3-ts-demo-2
✔ Add TypeScript? … No / Yes
✔ Add JSX Support? … No / Yes
✔ Add Vue Router for Single Page Application development? … No / Yes
✔ Add Pinia for state management? … No / Yes
✔ Add Vitest for Unit Testing? … No / Yes
✔ Add an End-to-End Testing Solution? › No
✔ Add ESLint for code quality? … No / Yes
✔ Add Prettier for code formatting? … No / Yes
✔ Add Vue DevTools 7 extension for debugging? (experimental) … No / Yes
```
`npm run dev`
2.引入element-plus
`npm install element-plus --save`
全局引入
```ts
// main.ts
import './assets/main.css'
import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import App from './App.vue'
import router from './router'
const app = createApp(App)
app.use(ElementPlus)
app.use(router)
app.mount('#app')
```
按需引入
```sh
npm install -D unplugin-vue-components unplugin-auto-import
```
`vite.config.ts`
```ts
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
// element-plus auto import
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
// https://vitejs.dev/config/
export default defineConfig({
plugins: [
vue(),
AutoImport({
resolvers: [ElementPlusResolver()]
}),
Components({
resolvers: [ElementPlusResolver()]
})
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url))
}
}
})
```
3.登录页:
### 视图和路由
安装插件:
```plaintext
Id: sdras.vue-vscode-snippets
Description: Snippets that will supercharge your Vue workflow
Version: 3.1.1
Publisher: sarah.drasner
VS Marketplace Link: https://marketplace.visualstudio.com/items?itemName=sdras.vue-vscode-snippets
```
使用代码片段:
![image-20240529145617816](./README.assets/image-20240529145617816.png)
安装 `scss`:`npm i -D sass`
修改 `router.ts`
```ts
import { createRouter, createWebHistory } from 'vue-router'
import HomeView from '../views/HomeView.vue'
import NotFoundView from '@/views/NotFoundView.vue'
const router = createRouter({
history: createWebHistory(import.meta.env.BASE_URL),
routes: [
{
path: '/',
name: 'home',
component: HomeView
},
{
path: '/about',
name: 'about',
component: () => import('../views/AboutView.vue')
},
{
path: '/login',
name: 'login',
component: () => import('../views/LoginView.vue')
},
{
path: '/:pathMatch(.*)*',
name: 'not-found',
component: NotFoundView
}
]
})
export default router
```
修改 `App.ts`
```vue
<script setup lang="ts">
import { RouterView } from 'vue-router'
</script>
<template>
<RouterView />
</template>
<style lang="scss">
* {
padding: 0;
margin: 0;
}
html,
body,
#app {
width: 100%;
height: 100%;
}
</style>
```
- 添加表单组件:
- 添加表单以和校验逻辑:
- 添加类型约束:
- 登录逻辑:
- 1.src-request-api.ts中引入并封装 axios
- 2.src-request-api创建接口
- 注释:通过
axios.create()
创建的service
,赋予了动态配置url
、method
和data
的能力,使得网络请求的处理更加灵活和高效。 - 3.添加登录逻辑,即登录成功后进行跳转
4.首页布局
### 头部
- 分为三部分:logo、标题、退出
对齐
- 侧边栏及动态路由并根据当前路由做菜单栏自动高亮
- 动态路由
- 默认重定向到 `/index`
## 05商品页
1.配置axios
src-request-api
2.定义数据->接口(通过ts规范)
src-type-goods
3.页面
4.页面逻辑脚本部分
服务端分页;前端渲染
### 搜索商品功能
## 06用户页
用户包含若干个角色,初始化数据为:
```js
var userList = [
{
id: 1,
nickName: '小明',
userName: '小明',
roles: [
{
id: 1,
name: '管理员'
},
{
id: 2,
name: '普通用户'
}
]
},
{
id: 2,
nickName: '红红',
userName: '红红',
roles: [
{
id: 1,
name: '管理员'
}
]
},
{
id: 3,
nickName: '绿绿',
userName: '绿绿',
roles: [
{
id: 2,
name: '普通用户'
}
]
}
]
var roleList = [
{
name: '管理员',
id: 1,
authority: [1, 2, 4, 5, 6, 7, 8, 9, 11, 13, 14, 15, 16]
},
{
name: '普通用户',
id: 2,
authority: [1, 3, 4, 6, 7, 8, 9, 11, 12, 13]
}
]
```
### 搜索区和表格
包含下拉框的搜索区
```vue
<el-form :inline="true" :model="selectData">
<el-form-item label="昵称">
<el-input v-model="selectData.nickName" clearable />
</el-form-item>
<el-form-item label="角色">
<el-select v-model="selectData.roleId" size="large" style="width: 240px">
<!-- 搜索时,如果 roleId=0 则去掉这个条件 -->
<el-option label="请选择" :value="0" />
<el-option
v-for="item in roleList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="handleSubmit">搜索</el-button>
</el-form-item>
</el-form>
```
表格:在角色一列,用插槽展示所有角色信息
```vue
<el-table :data="list" style="width: 100%" :border="true">
<el-table-column align="center" prop="id" label="ID" width="50"></el-table-column>
<el-table-column align="center" prop="nickName" label="昵称" width="150"></el-table-column>
<el-table-column prop="role" label="角色">
<template #default="scope">
<div class="roles-container">
<el-tag v-for="(item, index) in scope.row.roles" :key="index">{{ item.name }}</el-tag>
</div>
</template>
</el-table-column>
</el-table>
```
### 搜索用户功能
### 修改用户信息功能
在弹出对话框中呈现用于修改的表单
7.角色页:
接口->src-request-api
角色部分数据:
type-role
### 添加角色
添加后台接口,前台请求接口添加角色
### 展示角色
### 路由跳转
点击修改角色,会跳转到权限列表页,在这个页面中做角色信息修改
### 权限列表展示
使用树形控件展示角色的权限列表
### 权限列表修改
另外添加修改角色名的功能
如果让我来做,我会把角色信息修改的页面放在[抽屉](https://element-plus.org/zh-CN/component/drawer.html)里
## 08路由守卫和退出登录
退出登录时做二次提示