点击表头自动排序 java

在网上看到的,整理一下。


主要是 一个function

function TableSorter(table)
	{
	this.Table = this.$(table);
	if(this.Table.rows.length <= 1)
	{
	return;
	}
	this.Init(arguments);
	}
	//以下样式针对表头的单元格.
	TableSorter.prototype.NormalCss = "NormalCss";//没有执行排序时的样式.
	TableSorter.prototype.SortAscCss = "SortAscCss";//升序排序时的样式.
	TableSorter.prototype.SortDescCss = "SortDescCss";//降序排序时的样式.
	//初始化table的信息和操作.
	TableSorter.prototype.Init = function(args)
	{
	this.ViewState = [];
	for(var x = 0; x < this.Table.rows[0].cells.length; x++)
	{
	this.ViewState[x] = false;
	}
	if(args.length > 1)
	{
	for(var x = 1; x < args.length; x++)
	{
	if(args[x] > this.Table.rows[0].cells.length)
	{
	continue;
	}
	else
	{
	this.Table.rows[0].cells[args[x]].onclick = this.GetFunction(this,"Sort",args[x]);
	this.Table.rows[0].cells[args[x]].style.cursor = "pointer";
	}
	}
	}
	else
	{
	for(var x = 0; x < this.Table.rows[0].cells.length; x++)
	{
	this.Table.rows[0].cells[x].onclick = this.GetFunction(this,"Sort",x);
	this.Table.rows[0].cells[x].style.cursor = "pointer";
	}
	}
	}
	//简写document.getElementById方法.
	TableSorter.prototype.$ = function(element)
	{
	return document.getElementById(element);
	}
	//取得指定对象的脱壳函数.
	TableSorter.prototype.GetFunction = function(variable,method,param)
	{
	return function()
	{
	variable[method](param);
	}
	}
	//执行排序.
	TableSorter.prototype.Sort = function(col)
	{
	var SortAsNumber = true;
	for(var x = 0; x < this.Table.rows[0].cells.length; x++)
	{
	this.Table.rows[0].cells[x].className = this.NormalCss;
	}
	var Sorter = [];
	for(var x = 1; x < this.Table.rows.length; x++)
	{
	Sorter[x-1] = [this.Table.rows[x].cells[col].innerHTML, x];
	SortAsNumber = SortAsNumber && this.IsNumeric(Sorter[x-1][0]);
	}
	if(SortAsNumber)
	{
	for(var x = 0; x < Sorter.length; x++)
	{
	for(var y = x + 1; y < Sorter.length; y++)
	{
	if(parseFloat(Sorter[y][0]) < parseFloat(Sorter[x][0]))
	{
	var tmp = Sorter[x];
	Sorter[x] = Sorter[y];
	Sorter[y] = tmp;
	}
	}
	}
	}
	else
	{
	Sorter.sort();
	}
	if(this.ViewState[col])
	{
	Sorter.reverse();
	this.ViewState[col] = false;
	this.Table.rows[0].cells[col].className = this.SortDescCss;
	}
	else
	{
	this.ViewState[col] = true;
	this.Table.rows[0].cells[col].className = this.SortAscCss;
	}
	var Rank = [];
	for(var x = 0; x < Sorter.length; x++)
	{
	Rank[x] = this.GetRowHtml(this.Table.rows[Sorter[x][1]]);
	}
	for(var x = 1; x < this.Table.rows.length; x++)
	{
	for(var y = 0; y < this.Table.rows[x].cells.length; y++)
	{
	this.Table.rows[x].cells[y].innerHTML = Rank[x-1][y];
	}
	}
	this.OnSorted(this.Table.rows[0].cells[col], this.ViewState[col]);
	}
	//取得指定行的内容.
	TableSorter.prototype.GetRowHtml = function(row)
	{
	var result = [];
	for(var x = 0; x < row.cells.length; x++)
	{
	result[x] = row.cells[x].innerHTML;
	}
	return result;
	}
	TableSorter.prototype.IsNumeric = function(num)
	{
	return /^\d+(\.\d+)?$/.test(num);
	}
	//可自行实现排序后的动作.
	TableSorter.prototype.OnSorted = function(cell, IsAsc)
	{
	return;
	}

使用时,将要排序的表格new一下。

方法1:
new TableSorter("tb1");
效果:
id为tb1的table的第一行任意单元格都可以点击进行排序.
方法2:
new TableSorter("tb1", 0, 1, 3);
效果:
id为tb1的table的第一行0,1,3单元格可以进行点击排序.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要监听JTable的排序事件,可以通过添加TableModelListener和TableRowSorter的实现实现。以下是一个简单的示例代码: ```java import javax.swing.*; import javax.swing.event.TableModelEvent; import javax.swing.event.TableModelListener; import javax.swing.table.DefaultTableModel; import javax.swing.table.TableRowSorter; import java.util.ArrayList; import java.util.List; public class JTableSortListenerExample extends JFrame { private JTable table; private DefaultTableModel model; public JTableSortListenerExample() { setTitle("JTable Sort Listener Example"); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setSize(400, 300); // 创建表格模型及表格 model = new DefaultTableModel(); model.addColumn("ID"); model.addColumn("Name"); model.addColumn("Age"); table = new JTable(model); // 创建表格排序器 TableRowSorter<DefaultTableModel> sorter = new TableRowSorter<>(model); table.setRowSorter(sorter); // 添加表格模型的监听器 model.addTableModelListener(new TableModelListener() { @Override public void tableChanged(TableModelEvent e) { // 判断是否是排序事件 if (e.getType() == TableModelEvent.HEADER_ROW) { System.out.println("Table sorted by column " + table.convertColumnIndexToModel(sorter.getSortedColumns()[0])); } } }); // 初始化数据 List<Object[]> data = new ArrayList<>(); data.add(new Object[]{"1", "Alice", "18"}); data.add(new Object[]{"2", "Bob", "20"}); data.add(new Object[]{"3", "Charlie", "22"}); data.add(new Object[]{"4", "Dave", "24"}); data.add(new Object[]{"5", "Eve", "26"}); // 添加数据到表格模型 for (Object[] row : data) { model.addRow(row); } // 添加表格到窗口 add(new JScrollPane(table)); setVisible(true); } public static void main(String[] args) { new JTableSortListenerExample(); } } ``` 在上面的代码中,我们创建了一个JTable并添加了一个表格模型的监听器,用于监听表格排序事件。当表格按照某一列排序时,控制台会输出该列的索引(从0开始)。需要注意的是,我们使用了table.convertColumnIndexToModel()方法将视图中的列索引转换为模型中的列索引。 另外,我们还创建了一个TableRowSorter对象,并将其设置为JTable的排序器。这样,当用户点击表头时,JTable会自动按照该列进行排序
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值