Vue+Elementui实现多个表格table合并

技术关键点

slot="append"

这条代码用于卡槽,在表格末尾处添加你想要的样式

:show-header="false"

这条代码是用来忽略表格头

完整代码

<!DOCTYPE html>
<html>

	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<script src="https://unpkg.com/vue/dist/vue.js"></script>
	<script src="https://unpkg.com/element-ui@2.15.2/lib/index.js"></script>
	<style>
		@import url("//unpkg.com/element-ui@2.15.2/lib/theme-chalk/index.css");
	</style>
	<body>
		<div id="app">
			<el-table :data="tableData" border>
				<el-table-column align="center" min-width="80%" prop="id" label="ID">
				</el-table-column>
				<el-table-column align="center" min-width="80%" prop="name" label="名称">
				</el-table-column>
				<el-table-column align="center" min-width="80%" prop="money" label="金钱">
				</el-table-column>
				<div slot="append" style="text-align: center">
					<!--在此处添加你想要插入在表格最后一行的内容-->
					<el-table :data="costTableData" border :show-header="false">
						<el-table-column align="center" min-width="80%" prop="name" label="名字">
						</el-table-column>
						<el-table-column align="center" min-width="80%" prop="fy" label="费用">
						</el-table-column>
					</el-table>
				</div>
			</el-table>
		</div>
	</body>
	<script>
		var Main = {
			data() {
				return {
					tableData: [{
							id: 0,
							name: '西瓜',
							money:'2'
						},
						{
							id: 1,
							name: '冬瓜',
							money:'1'
						},
						{
							id: 2,
							name: '南瓜',
							money:'2'
						},
					],
					costTableData: [{
							name: '一个西瓜价格',
							fy: '25'
						},
						{
							name: '一个冬瓜价格',
							fy: '12'
						},
					],
				}
			},
			methods: {

			}
		}
		var Ctor = Vue.extend(Main)
		new Ctor().$mount('#app')
	</script>

</html>

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
实现表格分页,可以使用 ElementUI 提供的 el-pagination 组件,同时结合 el-table 组件使用。 1. 在 template 中添 el-pagination 组件和 el-table 组件: ``` <template> <div> <el-pagination :current-page="currentPage" :page-size="pageSize" :total="total" @current-change="handleCurrentChange"> </el-pagination> <el-table :data="tableData" border> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="age" label="年龄"></el-table-column> <el-table-column prop="address" label="地址"></el-table-column> </el-table> </div> </template> ``` 2. 在 data 中定义表格数据、分页相关数据以及每页显示的条目数: ``` <script> export default { data() { return { tableData: [], // 表格数据 currentPage: 1, // 当前页码 pageSize: 10, // 每页显示条目数 total: 0 // 总条目数 } }, methods: { handleCurrentChange(val) { this.currentPage = val; // 根据当前页码获取对应的数据 this.getData(); }, getData() { // 根据当前页码和每页显示条目数获取对应的数据 // 更新表格数据和总条目数 } } } </script> ``` 3. 在 mounted 中调用 getData 方法获取初始数据: ``` <script> export default { mounted() { this.getData(); }, methods: { // ... } } </script> ``` 4. 在 getData 方法中根据当前页码和每页显示条目数获取对应的数据,更新表格数据和总条目数: ``` <script> export default { methods: { async getData() { const res = await axios.get('/api/data', { params: { page: this.currentPage, size: this.pageSize } }); this.tableData = res.data.list; this.total = res.data.total; } } } </script> ``` 这样就可以实现基本的表格分页功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hikktn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值