Vue el-table的自定义排序返回值为null,设置刷新页面保持排序标志,导航时elementui组件不更新

自定义排序使用@sort-change="sortChange"监听,表列需设置为sortable="custom"(自定义)

html 复制代码
<el-table
		    :data="tableData"
		    border
			@sort-change="sortChange"
			:default-sort="{prop:sortProp,order:sortOrder}"
		    style="width: 100%"
			:key="tableKey+'table'">
			......
			<el-table-column
		      prop="date"
		      label="日期"
			  sortable="custom"
		      width="150">
		    </el-table-column>
		    ......
  • 排序事件传入参数格式为: {column: {...}, prop: 'commentnum', order: 'descending'},观察发现第一列排序时obj.order有'descending'、'ascending'、null三个值,有文章提到设置:sort-orders="['ascending', 'descending']",但此官方说明只支持sortable为true情况(默认表格排序)。所以我们需手动设置当obj.order为null情况。参考文章
js 复制代码
sortChange(obj){
			//{column: {...}, prop: 'commentnum', order: 'descending'}
			//{column: {...}, prop: 'commentnum', order: 'ascending'}
			// console.log(obj);
			this.sortProp=obj.prop;
			if (obj.order === null) {
				this.sortOrder === 'descending' ? obj.order = 'ascending' : obj.order = 'descending';
				obj.column.order = obj.order;
			}
			this.sortOrder=obj.order;
			//路由跳转
			this.$router.push({
			  path: "/doBlog",
			  query: { cp: 1 ,sortProp:this.sortProp,sortOrder:this.sortOrder,time:Date.now()},
			});	
		},
  • 刷新页面时要保持对应列的排序标志可设置:default-sort="{prop:sortProp,order:sortOrder}",刷新页面获取路由值即可。
  • 但如果是用导航栏切换页面,表头的排序标志依旧不更新,所以改变table的:key="tableKey+'table'"就能保证更新了。(适用于elementui其他组件)
js 复制代码
update(){
			this.currentPage=this.$route.query.cp?parseInt(this.$route.query.cp,10):1;
			this.sortProp=this.$route.query.sortProp?this.$route.query.sortProp:"id";
			this.sortOrder=this.$route.query.sortOrder?this.$route.query.sortOrder:"ascending";
			this.pageKey++;//强制更新分页组件
			this.tableKey++;//强制更新el-table排序标志
			//获取数据
			//。。。ajax
		}

在下面函数中调用刷新方法:

js 复制代码
	watch:{
	  	$route(){
			this.update();
	  	}
	},
	mounted() {
		this.update();	
	}	

解决了3个问题:1、自定义排序返回值为null;2、设置刷新页面保持排序标志;3、导航时elementui组件不更新

相关推荐
飞天大河豚17 分钟前
2025前端框架最新组件解析与实战技巧:Vue与React的革新之路
vue.js·react.js·前端框架
MickeyCV28 分钟前
Nginx学习笔记:常用命令&端口占用报错解决&Nginx核心配置文件解读
前端·nginx
祈澈菇凉1 小时前
webpack和grunt以及gulp有什么不同?
前端·webpack·gulp
zy0101011 小时前
HTML列表,表格和表单
前端·html
初辰ge1 小时前
【p-camera-h5】 一款开箱即用的H5相机插件,支持拍照、录像、动态水印与样式高度定制化。
前端·相机
HugeYLH1 小时前
解决npm问题:错误的代理设置
前端·npm·node.js
六个点2 小时前
DNS与获取页面白屏时间
前端·面试·dns
customer082 小时前
【开源免费】基于SpringBoot+Vue.JS医疗报销系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
道不尽世间的沧桑2 小时前
第9篇:插槽(Slots)的使用
前端·javascript·vue.js
B站计算机毕业设计超人2 小时前
计算机毕业设计SpringBoot+Vue.jst房屋租赁系统(源码+LW文档+PPT+讲解)
vue.js·spring boot·后端·eclipse·intellij-idea·mybatis·课程设计