PHP 报表排序及制作思路

报表排序实现原理

看到某宝、某猫上的排序,我试着照猫画虎,自己鼓捣一个。

原理记录如下:

1、前台部分

<table>
   <tr class="proghead">
      <td class="canclick progsort1" onclick="sort_prog(0)">学号</td>
	  <td class="canclick progsort2" onclick="sort_prog(1)">姓名</td>
   </tr>
</table>

2、CSS部分

.upsort:hover,.upsort{background:rgb(0,161,222) url(./css/up.png) no-repeat center right ; color:#fff; }
.downsort:hover, .downsort{background:rgb(0,161,222) url(./css/down.png) no-repeat  center right ; color:#fff; }

2、js部分

函数 sort_prog

var SORTPROG_FLAG = [0,0];
var SORTPROG_COL = ['sid','username'];

   //排序筛选
   function sort_prog(num){
        clear_arr(SORTPROG_FLAG,num);
        //更改显示标识 1升序
		if(SORTPROG_FLAG[num] === 0 || SORTPROG_FLAG[num] === 2){
			SORTPROG_FLAG[num] = 1;
		} 2 降序 否则不排序
		else if(SORTPROG_FLAG[num] === 1){
			SORTPROG_FLAG[num] = 2;
		}
		if(num >= 0){
			var htmlcode = '';
			$.ajax({
				'url':'./ajax.php',
				'data':get_param('prog'),
				'dataType':'text',
				'type':'post',
				'async':false,
				'success':function(data){
					if(data){
						$('.curseload').hide();
						htmlcode = data;
					}
				}
			});
			$('.progreport').html(htmlcode);
			//更改显示标识
			if(SORTPROG_FLAG[num] == 2){
				$('.'+obj).addClass('downsort').removeClass('upsort');
			}
			else if(SORTPROG_FLAG[num] == 1){
				$('.'+obj).addClass('upsort').removeClass('downsort');
			}
			$('.'+obj).siblings().removeClass('downsort').removeClass('upsort');

		}else{
			clear_arr(SORTPROG_FLAG,-1);
		    $.ajax({
				'url':'./ajax.php',
				'data':get_param('prog'),
				'dataType':'text',
				'type':'post',
				'success':function(data){
					if(data){
						$('.prog').html(data);
					}
				}
			});
		}
   }

   //数组清零 初始化
   function clear_arr(arr, index){
   	    var len = arr.length;
   	    for (var i= 0; i < len; i++) {
   	    	if(i != index){
   	       	    arr[i] = 0;
   	       	}
   	    }
   }

   //数组获取 点击索引
   function get_index(arr){
       var len = arr.length;
       var index = -1 ;
   	    for (var i = 0; i < len; i++) {
   	    	if(arr[i] != 0){
   	       	    index = i;
   	       	}
   	    }
   	    return index;
   }

   //参数获取
   //获取 参数
   function get_param(type){
   	   if(type == 'prog'){
   	   	    var num = get_index(SORT_FLAG);
   	   	    var sid = $('.sid').val();
			var username = $('.username').val();
		    return {'sid':sid,'username':username,'sort_col':SORTPROG_COL[num],'sort_type':SORTPROG_FLAG[num]};
   	   }
   }

3、PHP部分

class reportclass{
    //按列排序
    public function multi_array_sort($multi_array,$sort_key,$sort=SORT_ASC){
        $sorttype = optional_param('sorttype', 1, PARAM_RAW);
		if($sorttype == 1){
			$sort=SORT_ASC;
		}else if($sorttype == 2){
			$sort=SORT_DESC;
		}

		if(is_array($multi_array)){
			foreach ($multi_array as $row_array){
				if(is_array($row_array)){
					//将utf-8中文转换为 gbk 进行中文拼音排序
					$key_array[] = iconv('UTF-8', 'GBK', strip_tags($row_array[$sort_key]));
				}else{
					return false;
				}
			}
		}else{
			return false;
		}
		array_multisort($key_array,$sort,$multi_array);
		return $multi_array;
	}
	//
	public function print_report(){
	    $arr = get_report();
		$sort_col = $_POST['sort_col'];
		$sort_type = $_POST['sort_type'];
		if($sort_type == 1){$sort = SORT_ASC ;}
		else if($sort_type == 2){$sort = SORT_DESC ;}
	    $newarr = $this->multi_array_sort($arr,$sort_col,$sort);
		$this->show_report();
	}
	//实现获取 报表信息二维数组
	public function get_report(){}
	//根据二维数组 打印报表
	public function show_report(){}
}

代码并不完整,但是思路是完整的,欢迎不同见解者拍砖

然后附以下我个人做报表的思路图:

时间: 2024-10-09 21:54:27

PHP 报表排序及制作思路的相关文章

计数排序及其扩展思路

(1)原理和代码以及时间复杂度分析 1.计数排序的原理:设被排序的数组为A,排序后存储到B,C为临时数组.所谓计数,首先是通过一个数组C[i]计算大小等于i的元素个数,此过程只需要一次循环遍历就可以:在此基础上,计算小于或者等于i的元素个数,也是一重循环就完成.下一步是关键:逆序循环,从length[A]到1,将A[i]放到B中第C[A[i]]个位置上.原理是:C[A[i]]表示小于等于a[i]的元素个数,正好是A[i]排序后应该在的位置.而且从length[A]到1逆序循环,可以保证相同元素间

区间模糊排序---快排思路的应用

1 #include<iostream> 2 #include<ctime> 3 using namespace std; 4 #define max(a,b) (a>b)?a:b 5 #define min(a,b) (a>b)?b:a 6 class Interval 7 { 8 public: 9 double leftbound; 10 double rightbound; 11 Interval(int a, int b) :leftbound(a), rig

报表工具怎么制作带有时间轴的记录表?

想要制作一个时间轴记录事件的报表,通过报表工具要怎么制作呢?该怎么制作时间轴呢?下面我们就以润乾报表为例制作两种类型的时间轴记录表,具体看下如何实现. 简洁版时间轴 1. 增加数据集,将需要记录的时间和事件取到. 时间和事件数据我从 EXCEL 文件中读取,数据如下图所示: 报表设计器下新建一张报表,然后在“报表”菜单——数据集,中增加文件数据集. 选择 EXCEL 文件,然后选择字段点击确定. 建好数据集后,在报表设计界面右下角就可以看到新建的数据集字段名称,选中对应的字段分别拖拽到 B2,C

分享一种兼具UD、U+V2高端隐藏,支持UEFI和4GB大文件的U启制作思路

(zyphio原创博文,转载请注明作者和出处) 目前万能U启的主流技术有量产.UD.U+V2,个人不喜欢量产(相对UD.U+V2来说,量产兼容性也不算高,还不易编辑.写入损耗大,常常得纠结主控),U+V2更新镜像最自由灵活,但觉得兼容略逊于UD.UD的Fbinst技术还是GPL开源,作为有开源情结的我,个人还是最推崇UD,但也遇到过问题和无奈,所以就有此思路. --具体如下: 分区基本结构: UD+exFAT+FAT16(仅两个常规可见分区) 特殊的制作方法: 1.先分在U盘末端分出FAT16主

多种排序算法的思路和简单代码的实现(一)

就自己简单的理解了一些排序算法(JAVA)思路和代码分享给大家:欢迎大家进行交流. 直接插入排序,折半插入排序,冒泡排序,快速排序 1 public class Sort { 2 /* 3 * 直接插入排序: 先确定一个有序数组,然后把插入的数与有序数组从最后依次进行比较, 直到插入的数比有序数组的数大,此数换为插入的数字,从此位置以后 4 * 的数依次向后移动一位. 5 */ 6 public static void insert(int[] a) { 7 for (int i = 1; i

leetCode 21.Merge Two Sorted Lists (合并排序链表) 解题思路和方法

Merge Two Sorted Lists Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists. 思路:对两个已排序的单链表合并.算法上比较简单,与归并排序类似.只是数据结构上以前学的,现在忘的比较多,写第一遍的时候比较费力.而且想把重复代码写出方法,但是方法怎么都不

leetCode 23. Merge k Sorted Lists (合并k个排序链表) 解题思路和方法

Merge k Sorted Lists Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 思路:此题是由合并两个排序链表演化而来,刚开始,想法比较简单,像求最大公共前缀一样,逐一求解:但是最后超时,所以马上意识到出题方是为了使用归并和分治的方法,故重新写了代码. 代码一(超时未过): /** * Definition for singly-link

CCF计算机职业资格认证 2015年3月第2题 数字排序 解法和思路

问题描述 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序输出. 输入格式 输入的第一行包含一个整数n,表示给定数字的个数. 第二行包含n个整数,相邻的整数之间用一个空格分隔,表示所给定的整数. 输出格式 输出多行,每行包含两个整数,分别表示一个给定的整数和它出现的次数.按出现次数递减的顺序输出.如果两个整数出现的次数一样多,则先输出值较小的,然后输出值较大的. 样例输入 12 5 2 3 3 1 3 4 2 5 2 3 5 样例输出 3 4 2 3 5 3 1 1 4 1 评

报表分析工具制作气泡图

工具/原料 报表分析工具:FineReport7.1.1 大小:148.2M 适用平台:windows/linux 1. 概述 气泡图,是散点图的变体,不同的是,散点图使用的是成组的X.Y值(二维),而气泡图使用的是成组的X.Y.Z值(三维),其Z值确定气泡的大小. 如下气泡图来监视各调味品的单价.成本与库存订购量差: 2. 示例 2.1 数据准备 新建工作薄,添加数据集ds1,SQL语句为select 产品名称,成本价,单价,(库存量-订购量) as 库存订购量差 from 产品 where