iview treeSelect 组件封装
- 1、表格增加排序时触发的方法
- 2、定义三个变量,sortColumnDefaultStyle存放默认的样式,定义页面默认的列以及顺序
- 3、显示的列加上 sortable, 和样式
- 4、使用下面这块代表默认选中
- 5、点击时清除掉默认的排序
- 6、把排序的字段查询时传给后端
1、表格增加排序时触发的方法
data:image/s3,"s3://crabby-images/0ef60/0ef60cb41c1654bcbfb2e1a5db198769d0250fa4" alt="在这里插入图片描述"
Table(
:columns='columns'
:data='tableData'
@on-sort-change="sortChange"
)
2、定义三个变量,sortColumnDefaultStyle存放默认的样式,定义页面默认的列以及顺序
data:image/s3,"s3://crabby-images/2b405/2b405919e37d40d58dae70ca7e200dc165fc12c8" alt="在这里插入图片描述"
sortColumnDefaultStyle: null,
columnSorting: 'dialing_time',
sortingRules: 'desc',
3、显示的列加上 sortable, 和样式
data:image/s3,"s3://crabby-images/6771a/6771a38b6f73181db0eee4a30e2a5326e2138ce6" alt="在这里插入图片描述"
sortable: 'custom',
className: 'sort-column',
4、使用下面这块代表默认选中
data:image/s3,"s3://crabby-images/c764d/c764da98df9082cbb3827255c70edfec27c9a72c" alt="在这里插入图片描述"
mounted () {
this.$nextTick(() => {
this.sortColumnDefaultStyle = document.getElementsByClassName('sort-column')[0].getElementsByClassName('ivu-table-cell')[0].getElementsByClassName('ivu-table-sort')[0].getElementsByClassName('ivu-icon ivu-icon-arrow-down-b')[0]
this.sortColumnDefaultStyle.classList.add('on')
console.log('sortColumnDefaultStyle', this.sortColumnDefaultStyle)
})
},
5、点击时清除掉默认的排序
data:image/s3,"s3://crabby-images/bc78c/bc78cc5b5452333c453dcd0c823eacf458a356a0" alt="在这里插入图片描述"
sortChange (e) {
let key = e.key
const order = e.order
if (key === 'dialingTime') {
key = 'dialing_time'
} else if (key === 'timeCons') {
key = 'time_cons'
}
this.columnSorting = key
this.sortingRules = order
if (this.sortingRules === 'normal') {
this.columnSorting = null
this.sortingRules = null
}
if (this.sortColumnDefaultStyle) {
this.sortColumnDefaultStyle.classList.remove('on')
this.sortColumnDefaultStyle = null
}
this.query()
},
6、把排序的字段查询时传给后端
data:image/s3,"s3://crabby-images/50f49/50f496ea0d5c5bcef7e5a83ec2e379f0027d6234" alt="在这里插入图片描述"
orderBy: this.columnSorting,
order: this.sortingRules