php文件管理。能够点击依照时间。大小,名称排序

 本例没实用到jquery

 

PHP Code
  1. <?php   
  2. $rootdir="./";   
  3. $spacenum=0;   
  4. $filenum=0;   
  5. $allfilesize=0;   
  6. echo "<h1>文件管理freejs.net測试</h1>";   
  7. echo "<a href=''>重置</a>";   
  8. readLogDir($rootdir);   
  9. echo "<hr>";   
  10. echo "Total files count: $filenum.<br>";   
  11. echo "Total disk space used: $allfilesize<br>";   
  12. $freespace=diskfreespace("/");   
  13. echo "residue disk space: $freespace<br>";   
  14.   
  15. function readLogDir($subdir){   
  16. global $rootdir,$spacenum,$filenum,$allfilesize;   
  17.   
  18. @chdir($subdir) or die ("error:could not change to this directory!");   
  19. $dirobject=dir($subdir);   
  20. 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>";   
  21. $i=0;   
  22. while ($file=$dirobject->read()){   
  23.   
  24. if($file=="." || $file==".."){   
  25. continue;   
  26. }   
  27. $i=$i+1;   
  28. echo "<tr bgcolor='#e0e0e0'><td>".$i."<a href=.php?file_dir=".$rootdir."&file_name=".$file." target=_blank>";   
  29. 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>";   
  30. $allfilesize+=filesize($file);   
  31. $filenum++;   
  32. }   
  33. echo "</table>";   
  34. return;   
  35. }   
  36. ?

    >   

  37.   
  38. <script src="table_sort.js"></script>   

 

JavaScript Code
  1. /** 
  2. * table排序 
  3. * anthor liueh 
  4. */  
  5. function JM_PowerList(colNum)   
  6. {   
  7. headEventObject=event.srcElement;//取得引发事件的对象   
  8. while(headEventObject.tagName!="TR") //不是tr行,则从底下的td冒泡上来寻找到对应行   
  9. {   
  10. headEventObject=headEventObject.parentElement;   
  11. }   
  12.   
  13. for (i=0;i<headEventObject.children.length;i++)   
  14. {   
  15. if (headEventObject.children[i]!=event.srcElement)//找到事件发生的td单元格   
  16. {   
  17. headEventObject.children[i].className='listTableHead';//把点击的列的className属性设为listTableHead   
  18. }   
  19. }   
  20.   
  21. var tableRows=0;   
  22. trObject=clearStart.children[0].children; //取得表格中行对象, 原来这里叫DataTable, 可能是你写错了吧??   
  23. for (i=0;i<trObject.length;i++)   
  24. {   
  25. Object=clearStart.children[0].children[i];//取得每行的对象   
  26. tableRows=(trObject[i].id=='ignore')?

    tableRows:tableRows+1;//假设不是忽略行,则行数加一   

  27. }   
  28.   
  29. var trinnerHTML=new Array(tableRows);   
  30. var tdinnerHTML=new Array(tableRows);   
  31. var tdNumber=new Array(tableRows)   
  32. var i0=0   
  33. var i1=0   
  34. for (i=0;i<trObject.length;i++)   
  35. {   
  36. if (trObject[i].id!='ignore')   
  37. {   
  38. trinnerHTML[i0]=trObject[i].innerHTML;//把行放在数组里   
  39. tdinnerHTML[i0]=trObject[i].children[colNum].innerHTML;//把要排序的行中td的内容放数组里   
  40. tdNumber[i0]=i;//行号   
  41. i0++;//加一,下个循环用   
  42. }   
  43. }   
  44. sourceHTML=clearStart.children[0].outerHTML;//取得表格中全部tr的html代码   
  45.   
  46. //对全部td中的字符串进行排序, 算不算冒泡排序?

    ?

    ?   

  47. for (bi=0;bi<tableRows;bi++)   
  48. {   
  49. for (i=0;i<tableRows;i++)   
  50. {   
  51. if(tdinnerHTML[i]>tdinnerHTML[i+1])   
  52. {   
  53. t_s=tdNumber[i+1];   
  54. t_b=tdNumber[i];   
  55. tdNumber[i+1]=t_b;   
  56. tdNumber[i]=t_s;   
  57. temp_small=tdinnerHTML[i+1];   
  58. temp_big=tdinnerHTML[i];   
  59. tdinnerHTML[i+1]=temp_big;   
  60. tdinnerHTML[i]=temp_small;   
  61. }   
  62. }   
  63. }   
  64.   
  65.   
  66.   
  67. var showshow='';   
  68. var numshow='';   
  69. for (i=0;i<tableRows;i++)   
  70. {   
  71. showshow=showshow+tdinnerHTML[i]+'\n';//把排序好的td的内容存在showshow字串里   
  72. numshow=numshow+tdNumber[i]+'|'; //把排序好的对应的行号也存在numshow中   
  73. }   
  74.   
  75. sourceHTML_head=sourceHTML.split("<TBODY>");//从<TBODY>截断,我试了,前头串为空   
  76.   
  77. numshow=numshow.split("|");   
  78. var trRebuildHTML='';   
  79. if (event.srcElement.className=='listHeadClicked')   
  80. {//已点击的列, 则逆排   
  81. for (i=0;i<tableRows;i++)   
  82. {   
  83. trRebuildHTML=trRebuildHTML+trObject[numshow[tableRows-1-i]].outerHTML;//取出排序好的tr的内容连接起来   
  84.   
  85. }   
  86. event.srcElement.className='listHeadClicked0';   
  87. }   
  88. else   
  89. {//默认顺排,新点击顺排   
  90. for (i=0;i<tableRows;i++)   
  91. {   
  92. trRebuildHTML=trRebuildHTML+trObject[numshow[i]].outerHTML;   
  93. }   
  94. event.srcElement.className='listHeadClicked';   
  95. }   
  96. //取得排序后的tr集合结果字符串   
  97. var DataRebuildTable='';   
  98. //把旧的表格头和新的tr排序好的元素连接起来, (改动了一下)   
  99. DataRebuildTable = "<table border=0 width=600 id='clearStart' align='center'><TBODY>" + trObject[0].outerHTML + trRebuildHTML + "</TBODY>" +   
  100.   
  101. "</table>";   
  102. clearStart.outerHTML=DataRebuildTable;//表格用新串又一次写一次   
  103.   
  104. }   

 

原文地址:http://www.freejs.net/article_jquerywenzi_147.html

php文件管理,能够点击依照时间,大小,名称排序的更多相关文章

  1. C#文件和文件文件夹按时间、名称排序-顺序与倒序

    对于文件和文件夹有多种排序方式,常用的就是按创建或修改时间.按文件名排序.在 C# 中,按时间和文件名排序都十分简单,用数组提供的排序方法 Array.Sort() 一行代码就可以搞定,当然也可以用常 ...

  2. C#比较时间大小 1、比较时间大小的实验

    1.比较时间大小的实验    string st1="12:13"; string st2="14:14"; DateTime dt1=Convert.ToDa ...

  3. SQL 比较时间大小

    比较字符串类型的时间大小 数据库中的时间是varchar类型的,MySql使用CURDATE()来获取当前日期,SqlServer通过GETDATE()来获取当前日期 1. 直接使用字符串来比较 注意 ...

  4. js前端验证时间大小

    replace(/\-/g, "\/")是根据验证表达式把日期转化成长日期格式 function checkStartTimeAndEndTime(startTime, endTi ...

  5. C#里面比较时间大小三种方法

    1.比较时间大小的实验 string st1="12:13";string st2="14:14";DateTime dt1=Convert.ToDateTim ...

  6. WPF判断两个时间大小避免误差

    进行查询操作的时候,经常用到判断开始时间和结束时间大小的条件,由于从控件上获取的时间除了年月日时分秒,还包括毫秒.微秒等,导致直接判断时间大小的时候会产生一些误差,如下: 结果分析:年月日时分秒一致的 ...

  7. java计算时间差及比较时间大小(转)

    比如:现在是2004-03-26 13:31:40        过去是:2004-01-02 11:30:24 我现在要获得两个日期差,差的形式为:XX天XX小时XX分XX秒 方法一: DateFo ...

  8. js 日期时间大小比较

    <body> 开始时间:<input onfocus="setday(this)" id="startTime" name="sta ...

  9. Android JAVA中的时间大小比较

    import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; imp ...

随机推荐

  1. [nodejs] nodejs开发个人博客(二)入口文件

    错误处理中间件 定义错误处理中间件必须使用4个参数,否则会被作为普通中间件 /*错误处理器*/ application.use(function(err,req,res,next){ console. ...

  2. mybatis_05动态SQL_if和where

    If标签:作为判断入参来使用的,如果符合条件,则把if标签体内的SQL拼接上. 注意:用if进行判断是否为空时,不仅要判断null,也要判断空字符串‘’: Where标签:会去掉条件中的第一个and符 ...

  3. session图片验证码,页面和请求是两个地址。android手机好用,iphone 失效。

    问题描述:之前在H5页面用session做了一个验证码.安卓手机好使.但是到苹果就不好使了(页面访问是一个域名地址,ajax请求是用另外的一个ip地址). 详细说明: 验证码请求后台图片正常显示,an ...

  4. 反射demo(拷贝一个对象)

    经过了上一次对反射的初步认知,最近又接触到了后,做了一个小demo,感觉这次带了一点理解去做的,比第一次接触反射好了许多. 上次学习的链接,有一些反射用的基础语句.https://www.cnblog ...

  5. a dive in react lifecycle

    背景:我在react文档里找生命周期的图,居然没有,不敢相信我是在推特上找到的... 正文 react v16.3 新生命周期: static getDerivedStateFromProps get ...

  6. js控制随机数生成概率代码实例

    基本思路:把Math.random()js随机数生成的数看着百分比,然后定义每个整数值取值范围. 具体内容如下,供大家参考 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  7. 常见js面试题

    包含内容: Array indexOf(). 数组扁平化 isArray() 数组的去重 Object.is() Array.filter 用一行代码实现数组扁平化? JavaScript isArr ...

  8. layui table 表格模板按钮实例

    这是个是全部的jsp 页面: <%@page pageEncoding="UTF-8" contentType="text/html; charset=UTF-8& ...

  9. 【代码笔记】Web-Javascript-javascript break和continue语句

    一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  10. Android 程序崩溃之后fragment出现画面重叠问题

    1.解决方法: 直接在包含Fragment的Activity中复写onSaveInstanceState()方法,使其空实现 @Override protected void onSaveInstan ...