学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/humanResourceIntelligentManagementProject
搭建页面结构
分页组件:设置layout,表示需要显示的内容,用逗号分隔,布局元素会依次显示。prev表示上一页,next为下一页,pager表示页码列表(字母不要写错了)
<!-- 角色管理的内容 -->
<div class="role-operate">
<el-button size="mini" type="primary">添加角色</el-button>
</div>
<!-- 放置table表格组件 -->
<el-table>
<!-- 放置列 -->
<el-table-column align="center" width="200" label="角色" />
<el-table-column align="center" width="200" label="启用" />
<el-table-column align="center" label="描述" />
<el-table-column align="center" label="操作" />
</el-table>
<!-- 放置分页组件 -->
<el-row type="flex" style="height: 60px" align="middle" justify="end">
<!-- 放置分页组件 -->
<el-pagination layout="prev,pager,next" />
</el-row>
获取数据
/**
*
* 获取-分页查询角色列表
*
*/
export function getRoleList (params) {
return request({
url: '/sys/role',
method: 'GET',
params // 查询参数,会拼接到url地址上
})
}
<el-table :data="roleList">
<!-- 放置列 -->
<el-table-column align="center" width="200" prop="name" label="角色" />
<el-table-column align="center" width="200" prop="state" label="启用" />
<el-table-column align="center" prop="description" label="描述" />
<el-table-column align="center" label="操作" />
</el-table>
data () {
return {
roleList: [] // 角色列表
}
},
created () {
this.getRoleList()
},
methods: {
async getRoleList () {
const { rows } = await getRoleList()
this.roleList = rows // 赋值数据
}
}
表格自定义结构
启动列
<el-table-column align="center" width="200" prop="state" label="启用">
<!-- 自定义列结构 -->
<template v-slot="{ row }">
<span>
{{
row.state === 1 ? '已启用' : row.state === 0 ? '未启用' : '无'
}}</span
>
</template>
</el-table-column>
操作列
<el-table-column align="center" label="操作">
<!-- 放置操作按钮 -->
<template>
<el-button size="mini" type="text">分配权限</el-button>
<el-button size="mini" type="text">编辑</el-button>
<el-button size="mini" type="text">删除</el-button>
</template>
</el-table-column>
分页功能
<!-- 放置分页组件 -->
<el-pagination
:page-size="pageParams.pagesize"
:current-page="pageParams.page"
:total="pageParams.total"
layout="prev,pager,next"
@current-change="changePage"
/>
// 将分页信息放到一个对象中
pageParams: {
page: 1, // 第几页
pagesize: 5, // 每页多少条
total: 0
}
async getRoleList () {
const { rows, total } = await getRoleList(this.pageParams)
this.roleList = rows // 赋值数据
this.pageParams.total = total
},
// 切换分页时,请求新的数据
changePage (newPage) {
this.pageParams.page = newPage // 赋值当前页码
this.getRoleList()
}
新增功能弹层
<el-button size="mini" type="primary" @click="showDialog = true"
>添加角色</el-button>
<!-- 放置弹层 -->
<el-dialog title="新增角色" width="500px" :visible.sync="showDialog">
<!-- 表单内容 -->
<el-form
label-width="120px"
>
<el-form-item label="角色名称">
<el-input style="width: 300px" size="mini" />
</el-form-item>
<el-form-item label="启用">
<el-switch
size="mini"
/>
</el-form-item>
<el-form-item label="角色描述" >
<el-input
type="textarea"
:rows="3"
style="width: 300px"
size="mini"
/>
</el-form-item>
<el-form-item>
<el-row type="flex" justify="center">
<el-col :span="12">
<el-button type="primary" size="mini">确认</el-button>
<el-button size="mini">取消</el-button>
</el-col>
</el-row>
</el-form-item>
</el-form>
</el-dialog>
showDialog: false, // 控制弹层显示隐藏
表单数据校验
<!-- 放置弹层 -->
<el-dialog title="新增角色" width="500px" :visible.sync="showDialog">
<!-- 表单内容 -->
<el-form
ref="roleForm"
:model="roleForm"
:rules="rules"
label-width="120px"
>
<el-form-item label="角色名称" prop="name">
<el-input v-model="roleForm.name" style="width: 300px" size="mini" />
</el-form-item>
<!-- 如果不需要校验,就不需要写prop属性 -->
<el-form-item label="启用">
<el-switch
v-model="roleForm.state"
:active-value="1"
:inactive-value="0"
size="mini"
/>
</el-form-item>
<el-form-item label="角色描述" prop="description">
<el-input
v-model="roleForm.description"
type="textarea"
:rows="3"
style="width: 300px"
size="mini"
/>
</el-form-item>
<el-form-item>
<el-row type="flex" justify="center">
<el-col :span="12">
<el-button type="primary" size="mini">确认</el-button>
<el-button size="mini">取消</el-button>
</el-col>
</el-row>
</el-form-item>
</el-form>
</el-dialog>
roleForm: {
name: '',
state: 0,
description: ''
},
rules: {
name: [
{ required: true, message: '角色名称不能为空', trigger: 'blur' }
],
description: [
{ required: true, message: '角色描述不能为空', trigger: 'blur' }
]
}
新增角色-确定取消
/**
*
* 新增-角色
*
*/
export function addRole (data) {
return request({
url: '/sys/role',
method: 'POST',
data
})
}
<!-- 如果不需要校验,就不需要写prop属性 -->
<!-- 重置表单数据,需要prop属性 -->
<el-form-item label="启用" prop="state">
<el-switch
v-model="roleForm.state"
:active-value="1"
:inactive-value="0"
size="mini"
/>
</el-form-item>
btnOk () {
this.$refs.roleForm.validate(async isOk => {
if (isOk) {
// 调用新增接口
await addRole(this.roleForm)
// 重新渲染页面并关闭弹层
this.getRoleList()
this.btnCancel()
this.$message.success('添加成功')
}
})
},
btnCancel () {
this.$refs.roleForm.resetFields() // 将数据重置
this.showDialog = false
}
编辑角色-行内编辑
this.$set(目标对象, 属性名称, 初始值 )
等价于 Vue.set(目标对象, 属性名称, 初始值 )
向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新
<!-- 放置列 -->
<el-table-column align="center" width="200" prop="name" label="角色">
<template v-slot="{ row }">
<!-- 条件判断 -->
<el-input v-if="row.isEdit" size="mini" />
<span v-else>{{ row.name }}</span>
</template>
</el-table-column>
<el-table-column align="center" width="200" prop="state" label="启用">
<!-- 自定义列结构 -->
<template v-slot="{ row }">
<el-switch v-if="row.isEdit" />
<span v-else>
{{
row.state === 1 ? '已启用' : row.state === 0 ? '未启用' : '无'
}}
</span>
</template>
</el-table-column>
<el-table-column align="center" prop="description" label="描述">
<template v-slot="{ row }">
<el-input v-if="row.isEdit" size="mini" />
<span v-else>{{ row.description }}</span>
</template>
</el-table-column>
<el-table-column align="center" label="操作">
<!-- 放置操作按钮 -->
<template v-slot="{ row }">
<!-- 编辑状态 -->
<template v-if="row.isEdit">
<el-button type="primary" size="mini">确定</el-button>
<el-button size="mini">取消</el-button>
</template>
<!-- 非编辑状态 -->
<template v-else
><el-button size="mini" type="text">分配权限</el-button>
<el-button size="mini" type="text" @click="btnEditRow(row)"
>编辑</el-button
>
<el-button size="mini" type="text">删除</el-button></template
>
</template>
</el-table-column>
// 针对每一行数据添加一个编辑标记
this.roleList.forEach(item => {
// item.isEdit = false // 添加一个属性 初始值为false
// 数据响应式的问题 数据变化 视图更新
// 添加的动态属性 不具备响应式特点
// this.$set(目标对象,属性名称,初始值)可以针对目标对象 添加的属性 添加响应式
this.$set(item, 'isEdit', false)
})
// 点击编辑行
btnEditRow (row) {
console.log(row)
row.isEdit = true
}
编辑角色-行内数据缓存
<el-input
v-if="row.isEdit"
v-model="row.editRow.name"
size="mini"
/>
<!-- 开 1 关 0 -->
<el-switch
v-if="row.isEdit"
v-model="row.editRow.state"
:active-value="1"
:inactive-value="0"
/>
<el-input
v-if="row.isEdit"
v-model="row.editRow.description"
size="mini"
/>
// 初始化定义缓存数据
this.$set(item, 'editRow', {
name: item.name,
state: item.state,
description: item.description}
// 点击编辑行
btnEditRow (row) {
row.isEdit = true
// 更新缓存数据
row.editRow.name = row.name
row.editRow.state = row.state
row.editRow.description = row.description
},
编辑角色-确定取消
/**
*
* 修改-角色
*
*/
export function updateRole (data) {
return request({
url: `/sys/role/${data.id}`,
method: 'PUT',
data
})
}
<el-button type="primary" size="mini" @click="btnEditOk(row)"
>确定</el-button
>
<el-button size="mini" @click="row.isEdit = false"
>取消</el-button
>
async btnEditOk (row) {
// 检查必填
if (row.editRow.name && row.editRow.description) {
// 调用更新接口
await updateRole({ ...row.editRow, id: row.id })
this.$message.success('更新数据成功')
// 更新显示数据 退出编辑状态
// row.name=row.editRow.name //eslint的校验(误判)
// Object.assign(target,source)
Object.assign(row, {
...row.editRow,
isEdit: false // 退出编辑模式
}) // 规避eslint的误判
} else {
this.$message.warning('角色和描述不能为空')
}
}
角色管理-删除角色
/**
*
* 删除-角色
*
*/
export function deleteRole (id) {
return request({
url: `/sys/role/${id}`,
method: 'DELETE'
})
}
<el-popconfirm
title="这是一段内容确定删除吗?"
@onConfirm="confirmDel(row.id)"
>
<el-button
slot="reference"
style="margin-left: 10px"
size="mini"
type="text"
>删除</el-button
>
</el-popconfirm>
// 点击了确定触发的
async confirmDel (id) {
await deleteRole(id) // 后端删除
this.$message.success('删除数据成功')
// 删除的如果是最后一个
if (this.roleList.length === 1) this.pageParams.page--
this.getRoleList()
}