当前位置: 首页 > news >正文

PHP 报告分拣和生产理念

原则排序报告

见一宝、一只猫的排序,我想照猫画虎,鼓捣自己一个。

原理记录例如以下:
1、前台部分


<table>
   <tr class="proghead">
      <td class="canclick progsort1" οnclick="sort_prog(0)">学号</td>
	  <td class="canclick progsort2" οnclick="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(){}
}

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

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






相关文章:

  • yum 安装包时提示Error: Missing Dependency: php-common
  • GO --微服务框架(二) goa
  • 给电脑配置镜像,加快npm下载第三方依赖包速度
  • 深入理解java异常处理机制
  • Windows Server 2008无法更新时间
  • 字符串操作
  • device tree website
  • NYOJ 113 字符串替换(C++STL解法)
  • 2.MyBatis 框架原理
  • 201604-201704格尔斯常用链接记录
  • java多线程基本概述(二十一)——BlockingQueue
  • 【安德鲁斯】基于脚本的数据库quot;增量更新quot;,如果不改变,每次更新java代码、!...
  • Django开发BBS---51网络课程笔记(1)
  • 问题之ssh中Host key verification failed的解决
  • 计算机是如何做加法的?(7)——回顾与总结
  • Babel配置的不完全指南
  • centos安装java运行环境jdk+tomcat
  • ES6 ...操作符
  • Java方法详解
  • jquery cookie
  • laravel5.5 视图共享数据
  • Netty 4.1 源代码学习:线程模型
  • vue 个人积累(使用工具,组件)
  • vuex 学习笔记 01
  • 翻译:Hystrix - How To Use
  • 批量截取pdf文件
  • 区块链将重新定义世界
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 世界编程语言排行榜2008年06月(ActionScript 挺进20强)
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 用jQuery怎么做到前后端分离
  • 怎么将电脑中的声音录制成WAV格式
  • 你对linux中grep命令知道多少?
  • 说说我为什么看好Spring Cloud Alibaba
  • (4)事件处理——(7)简单事件(Simple events)
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (二)linux使用docker容器运行mysql
  • (欧拉)openEuler系统添加网卡文件配置流程、(欧拉)openEuler系统手动配置ipv6地址流程、(欧拉)openEuler系统网络管理说明
  • (篇九)MySQL常用内置函数
  • (一)搭建springboot+vue前后端分离项目--前端vue搭建
  • (转)菜鸟学数据库(三)——存储过程
  • (转)平衡树
  • .NET C#版本和.NET版本以及VS版本的对应关系
  • .NET Core日志内容详解,详解不同日志级别的区别和有关日志记录的实用工具和第三方库详解与示例
  • .NET 编写一个可以异步等待循环中任何一个部分的 Awaiter
  • .net 反编译_.net反编译的相关问题
  • .net2005怎么读string形的xml,不是xml文件。
  • .NET基础篇——反射的奥妙
  • .net流程开发平台的一些难点(1)
  • .NET文档生成工具ADB使用图文教程
  • @DateTimeFormat 和 @JsonFormat 注解详解
  • @entity 不限字节长度的类型_一文读懂Redis常见对象类型的底层数据结构
  • [20180312]进程管理其中的SQL Server进程占用内存远远大于SQL server内部统计出来的内存...
  • [2024] 十大免费电脑数据恢复软件——轻松恢复电脑上已删除文件
  • [22]. 括号生成