运用 element ui组件 表格 分页器
2023-12-26 13:09:36
<template>
<div>
<div class="top">
<el-form ref="form" :model="form" label-width="130px" :inline="true" class="form">
<el-form-item label="费用科目">
<el-select v-model="form.iExpenseSubject" @change="handleExpenseSubjectChange">
<el-option label="业招费" value="1"></el-option>
<el-option label="会议费" value="2"></el-option>
<el-option label="差旅费 " value="3"></el-option>
<el-option label="办公费" value="4"></el-option>
<el-option label="职工教育经费 " value="5"></el-option>
<el-option label="特殊资金工会经费 " value="5"></el-option>
</el-select>
</el-form-item>
<el-form-item label="会计账期">
<el-select v-model="form.dAccountPeriod" @change="handleExpenseSubjectChange">
<el-option label="YYYY-MM" value="2022-09"></el-option>
<el-option label="区域二" value="beijing"></el-option>
</el-select>
</el-form-item>
<el-form-item label="问题类型">
<el-select v-model="form.iProblemType" @change="handleExpenseSubjectChange">
<el-option label="区域一" value="1"></el-option>
<el-option label="区域二" value="2"></el-option>
</el-select>
</el-form-item>
</el-form>
<div class="fenye">
<div></div>
<div class="btns">
<el-button
class="btn"
v-for="(button, index) in buttons"
@click="button.handler"
v-if="button.show"
:icon="button.icon"
:key="index"
:type="button.type"
>{{ button.name }}
</el-button>
</div>
</div>
</div>
<div style="margin-top: 50px;" >
<el-table id ="editAbleTrends" @selection-change="handleSelectionChange" ref="dataTable" :data="tableData" :summary-method="getSummaries" show-summary row-key="id" >
<el-table-column type="selection" @click="checkMe(scope.row.$index)" align="center" width="40"></el-table-column>
<el-table-column type="index" :index="indexMethod" label="序号" align="center" width="60"></el-table-column>
<el-table-column prop="" label="凭证信息" align="center">
<el-table-column prop="checkInfo.vocherInfo.iexpenseSubject" label="费用科目" align="center"></el-table-column>
<el-table-column prop="checkInfo.vocherInfo.dAccountPeriod" label="会计账期" align="center"></el-table-column>
<el-table-column prop="checkInfo.vocherInfo.scode" label="凭证编号" align="center"></el-table-column>
<el-table-column prop="checkInfo.vocherInfo.ssummary" label="凭证摘要" align="center"></el-table-column>
<el-table-column prop="checkInfo.vocherInfo.ifeeAmount" label="凭证金额" align="center"></el-table-column>
<el-table-column prop="checkInfo.vocherInfo.sflowCode" label="流程编号" align="center"></el-table-column>
</el-table-column>
<el-table-column prop="" label="检查情况" align="center">
<el-table-column prop="checkInfo.icheckForm" label="检查形式" align="center"></el-table-column>
<el-table-column prop="checkInfo.dcheckTime" label="检查时间" align="center"></el-table-column>
<el-table-column prop="checkInfo.scheckWorkName" label="检查工作名称" align="center"> </el-table-column>
<el-table-column prop="checkInfo.icheckType" label="检查类型" align="center"></el-table-column>
<el-table-column prop="checkInfo.icheckStaffId" label="检查人员" align="center"></el-table-column>
<el-table-column prop="iproblemType" label="问题类别" align="center"></el-table-column>
</el-table-column>
</el-table>
</div>
<div class="fenye">
<div></div>
<div class="block">
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="page"
:page-sizes="[5, 10, 15, 20]"
:page-size="pageSize"
layout="total,sizes,prev,pager,next,jumper"
:total="total">
</el-pagination>
</div>
</div>
</div>
</template>
<script>
import {getProblemledgerAPI} from '@/api/znjd'
export default {
name:'problemSum',
data() {
return {
//表格中选中的数据
selectData:[],
tableData: [],
pageSize:5,
page:1,
total:'',
buttons:[
{
name:'查询',
plain: false,
type:'primary',
show:true,
handler:()=>{
this.Problemledger()
}
},
{
name:'导出',
plain: false,
type: 'primary',
show:true,
handler:()=>{
console.log('ffff')
}
},
],
form:{
iExpenseSubject:null,
dAccountPeriod:null,
iProblemType:null
},
ProblemledgerList:[],
}
},
created(){
this.Problemledger()
},
methods: {
// 解决点击下一页序号从1开始问题
indexMethod(index) {
return index + 1 + (this.page - 1) * this.pageSize // page是当前的页码,size是页码容量
},
//获取序号勾选中的所有数据
handleSelectionChange(val) {
// this.selectData = val;
console.log('ooo',val)
this.selectData = val;
},
getSummaries(columns){
console.log(columns);
},
//最上面的三个查询下拉事件
handleExpenseSubjectChange(){
},
//切换页面
handleSizeChange(val) {
this.pageSize = val;
this.page = 1;
this.Problemledger()
console.log('9898',val)
},
handleCurrentChange(val) {
this.page = val;
this.Problemledger()
},
//调接口
Problemledger(){
const params = {
key:{
page: this.page,
pageSize: this.pageSize,
},
dAccountPeriod: Number(this.form.dAccountPeriod)||null,
iProblemType: this.form.iProblemType||null,
iExpenseSubject: Number(this.form.iExpenseSubject)||null,
};
getProblemledgerAPI(params).then(res=>{
console.log('666',res)
this.tableData = res.data.data;
this.total =res.data.total;
console.log('qijsi',res.data.pageSize)
}).catch(err=>{
console.log('ssansia',err)
})
},
//导出
exportWord() {
const ids = this.ids; // ids:1,2,3
exportFile(ids).then((res) => {
let content = res.data; // 文件流
let fileName = 'filename.zip'; // 压缩包文件的文件名,可以根据实际情况修改扩展名
// 创建Blob对象
let blob = new Blob([content], { type: 'application/zip' });
// 创建下载链接
let link = document.createElement('a');
link.href = URL.createObjectURL(blob);
link.download = fileName;
link.style.display = 'none';
// 添加链接到页面上
document.body.appendChild(link);
// 触发点击事件以开始下载
link.click();
// 清理链接和URL对象
URL.revokeObjectURL(link.href);
document.body.removeChild(link);
// 显示导出成功消息
this.$message({
message: "导出成功",
type: "success",
});
})
.catch((error) => {
// 处理导出失败的情况
console.error(error);
this.$message({
message: "导出失败",
type: "error",
});
});
},
},
}
</script>
<style scoped lany="scss">
.top{
margin-top: 20px;
display: flex;
justify-content: space-between;
}
.btns{
margin-right: 50px;
}
.btn{
background-color: rgb(24, 144, 255);
border-radius: 5.5px;
opacity: 1;
width: 90px;
height: 30px;
color: #fff;
margin-left: 30px;
}
.fenye{
display: flex;
justify-content: space-between;
}
</style>
文章来源:https://blog.csdn.net/my4299/article/details/135157116
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!