php文件管理,能够点击依照时间,大小,名称排序
php文件管理。能够点击依照时间。大小,名称排序
本例没实用到jquery

- <?php
- $rootdir="./";
- $spacenum=0;
- $filenum=0;
- $allfilesize=0;
- echo "<h1>文件管理freejs.net測试</h1>";
- echo "<a href=''>重置</a>";
- readLogDir($rootdir);
- echo "<hr>";
- echo "Total files count: $filenum.<br>";
- echo "Total disk space used: $allfilesize<br>";
- $freespace=diskfreespace("/");
- echo "residue disk space: $freespace<br>";
- function readLogDir($subdir){
- global $rootdir,$spacenum,$filenum,$allfilesize;
- @chdir($subdir) or die ("error:could not change to this directory!");
- $dirobject=dir($subdir);
- echo "<table width=600 border=0 align='center' id='clearStart'><tr id='ignore' ><td width=40% onclick='JM_PowerList(0)'><b>文件名称</b></a></td><td width=20% onclick='JM_PowerList(1)'><b>文件大小</b></td><td width=40% onclick='JM_PowerList(2)'><b>创建时间</b></td></tr>";
- $i=0;
- while ($file=$dirobject->read()){
- if($file=="." || $file==".."){
- continue;
- }
- $i=$i+1;
- echo "<tr bgcolor='#e0e0e0'><td>".$i."<a href=.php?file_dir=".$rootdir."&file_name=".$file." target=_blank>";
- echo $file."</a></td><td>". number_format((filesize($file)/1024),2,'.','')."KB</td><td>". date("Y-m-d H:i:s", filemtime($file)). "</td></tr>";
- $allfilesize+=filesize($file);
- $filenum++;
- }
- echo "</table>";
- return;
- }
- ?
>
- <script src="table_sort.js"></script>
- /**
- * table排序
- * anthor liueh
- */
- function JM_PowerList(colNum)
- {
- headEventObject=event.srcElement;//取得引发事件的对象
- while(headEventObject.tagName!="TR") //不是tr行,则从底下的td冒泡上来寻找到对应行
- {
- headEventObject=headEventObject.parentElement;
- }
- for (i=0;i<headEventObject.children.length;i++)
- {
- if (headEventObject.children[i]!=event.srcElement)//找到事件发生的td单元格
- {
- headEventObject.children[i].className='listTableHead';//把点击的列的className属性设为listTableHead
- }
- }
- var tableRows=0;
- trObject=clearStart.children[0].children; //取得表格中行对象, 原来这里叫DataTable, 可能是你写错了吧??
- for (i=0;i<trObject.length;i++)
- {
- Object=clearStart.children[0].children[i];//取得每行的对象
- tableRows=(trObject[i].id=='ignore')?
tableRows:tableRows+1;//假设不是忽略行,则行数加一
- }
- var trinnerHTML=new Array(tableRows);
- var tdinnerHTML=new Array(tableRows);
- var tdNumber=new Array(tableRows)
- var i0=0
- var i1=0
- for (i=0;i<trObject.length;i++)
- {
- if (trObject[i].id!='ignore')
- {
- trinnerHTML[i0]=trObject[i].innerHTML;//把行放在数组里
- tdinnerHTML[i0]=trObject[i].children[colNum].innerHTML;//把要排序的行中td的内容放数组里
- tdNumber[i0]=i;//行号
- i0++;//加一,下个循环用
- }
- }
- sourceHTML=clearStart.children[0].outerHTML;//取得表格中全部tr的html代码
- //对全部td中的字符串进行排序, 算不算冒泡排序?
?
?
- for (bi=0;bi<tableRows;bi++)
- {
- for (i=0;i<tableRows;i++)
- {
- if(tdinnerHTML[i]>tdinnerHTML[i+1])
- {
- t_s=tdNumber[i+1];
- t_b=tdNumber[i];
- tdNumber[i+1]=t_b;
- tdNumber[i]=t_s;
- temp_small=tdinnerHTML[i+1];
- temp_big=tdinnerHTML[i];
- tdinnerHTML[i+1]=temp_big;
- tdinnerHTML[i]=temp_small;
- }
- }
- }
- var showshow='';
- var numshow='';
- for (i=0;i<tableRows;i++)
- {
- showshow=showshow+tdinnerHTML[i]+'\n';//把排序好的td的内容存在showshow字串里
- numshow=numshow+tdNumber[i]+'|'; //把排序好的对应的行号也存在numshow中
- }
- sourceHTML_head=sourceHTML.split("<TBODY>");//从<TBODY>截断,我试了,前头串为空
- numshow=numshow.split("|");
- var trRebuildHTML='';
- if (event.srcElement.className=='listHeadClicked')
- {//已点击的列, 则逆排
- for (i=0;i<tableRows;i++)
- {
- trRebuildHTML=trRebuildHTML+trObject[numshow[tableRows-1-i]].outerHTML;//取出排序好的tr的内容连接起来
- }
- event.srcElement.className='listHeadClicked0';
- }
- else
- {//默认顺排,新点击顺排
- for (i=0;i<tableRows;i++)
- {
- trRebuildHTML=trRebuildHTML+trObject[numshow[i]].outerHTML;
- }
- event.srcElement.className='listHeadClicked';
- }
- //取得排序后的tr集合结果字符串
- var DataRebuildTable='';
- //把旧的表格头和新的tr排序好的元素连接起来, (改动了一下)
- DataRebuildTable = "<table border=0 width=600 id='clearStart' align='center'><TBODY>" + trObject[0].outerHTML + trRebuildHTML + "</TBODY>" +
- "</table>";
- clearStart.outerHTML=DataRebuildTable;//表格用新串又一次写一次
- }
php文件管理,能够点击依照时间,大小,名称排序的更多相关文章
- C#文件和文件文件夹按时间、名称排序-顺序与倒序
对于文件和文件夹有多种排序方式,常用的就是按创建或修改时间.按文件名排序.在 C# 中,按时间和文件名排序都十分简单,用数组提供的排序方法 Array.Sort() 一行代码就可以搞定,当然也可以用常 ...
- C#比较时间大小 1、比较时间大小的实验
1.比较时间大小的实验 string st1="12:13"; string st2="14:14"; DateTime dt1=Convert.ToDa ...
- SQL 比较时间大小
比较字符串类型的时间大小 数据库中的时间是varchar类型的,MySql使用CURDATE()来获取当前日期,SqlServer通过GETDATE()来获取当前日期 1. 直接使用字符串来比较 注意 ...
- js前端验证时间大小
replace(/\-/g, "\/")是根据验证表达式把日期转化成长日期格式 function checkStartTimeAndEndTime(startTime, endTi ...
- C#里面比较时间大小三种方法
1.比较时间大小的实验 string st1="12:13";string st2="14:14";DateTime dt1=Convert.ToDateTim ...
- WPF判断两个时间大小避免误差
进行查询操作的时候,经常用到判断开始时间和结束时间大小的条件,由于从控件上获取的时间除了年月日时分秒,还包括毫秒.微秒等,导致直接判断时间大小的时候会产生一些误差,如下: 结果分析:年月日时分秒一致的 ...
- java计算时间差及比较时间大小(转)
比如:现在是2004-03-26 13:31:40 过去是:2004-01-02 11:30:24 我现在要获得两个日期差,差的形式为:XX天XX小时XX分XX秒 方法一: DateFo ...
- js 日期时间大小比较
<body> 开始时间:<input onfocus="setday(this)" id="startTime" name="sta ...
- Android JAVA中的时间大小比较
import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; imp ...
随机推荐
- mybatis整合springboot 以及需要注意的细节
具体怎么整合的网上有很多优秀的博客介绍,这里就直接引用一篇个人觉得非常详细的教程: https://blog.csdn.net/winter_chen001/article/details/77249 ...
- css重写checkbox样式
一.前言 默认的checkbox长这样: <p> <span><input type="checkbox" /></span> &l ...
- linux查看用户、创建用户、设置密码、修改用户、删除用户命令
查看用户 /etc/passwd /etc/shadow id alex ' |passwd --stdin alex # 设置密码,不需要交互 [root@localhost ~]# tail -l ...
- 人类阅读的优越方式打印php数组
在程序开发过程中:打印数据进行查看调试是非常频繁的:如果没有一种易于阅读的样式那是相当痛苦的:先定义一个数组: $array=array( 't0'=>'test0', 't1'=>'te ...
- Eslint使用(webpack中使用)
一.安装 npm i -D eslint npm i babel-eslint \ eslint-config-airbnb \ // Airbnb的编码规范是在业界非常流行的一套规范 eslint- ...
- babel在项目里的使用
1.手动在项目里创建文件 .babelrc 2.安装 $ npm install --save-dev babel-cli # ES2015转码规则 $ npm install --save-dev ...
- Android项目实战(五十):微信支付 坑总结
大部分APP必备需求,使用总结 Android接入文章在此:官方文档 文档很简单,Android分为四步: 1.后台配置 2.Android 内 注册appId 3.Android 内 调起支付 4. ...
- mysql之外键
本文内容: 什么是外键 外键的增加 外键的修改和删除 外键的约束模式 首发日期:2018-04-12 什么是外键: 外键就是表中存在一个字段指向另外一个表的主键,那么这个字段就可以称为外键. 一张表可 ...
- NAT穿越(一) NAT类型
NAT分为四种类型: (1)完全透明NAT(Full Cone NAT): 从内部主机 (IN IP ipa) +端口(IN PORT porta) 发送的数据映射为 IP(OUT IP IPA) ...
- mysql练习----SUM and COUNT/zh图(二)
世界国家概况 GROUP BY 和 HAVING 通过包括一个GROUP BY子句功能, SUM并将COUNT 其应用于共享值的项目组.当你指定 GROUP BY continent 结果是每个不同的 ...