<?php header('content-type:text/html;charset=utf8'); if(isset($_GET['page'])){ $page=$_GET['page']; }else{ $page=1; } //定义一个用于截取一段字符串的函数msubstr() function msubstr($str,$start,$len){ //$str指的是字符串,$start指的是字符串的起始位置,$len指的是长度。 $tmpstr=""; $strlen=$start+$len; //用$strlen存储字符串的总长度(从字符串的起始位置到字符串的总长度) for($i=0;$i<$strlen;$i++){ //通过for循环语句,循环读取字符串 if(ord(substr($str,$i,1))>0xa0){ //如果字符串中首个字节的ASCII序数值大于0xa0,则表示为汉字 $tmpstr.=substr($str,$i,2); //每次取出两位字符赋给变量$tmpstr,即等于一个汉字 $i++; //变量自加1 }else{ //如果不是汉字,则每次取出一位字符赋给变量$tmpstr $tmpstr.=substr($str,$i,1);} } return $tmpstr; //输出字符串 } ?> <div id="synopsis"> <table width="100%" border="0" cellspacing="0" cellpadding="0"> <tr> <td height="20"> </td> </tr> <tr> <td> <?php if($page){ $counter=file_get_contents("test.txt"); $length=strlen($counter); //读取超长文本数据,实现超长文本中数据的分页显示 $page_count=ceil($length/2048); //计算页数,四舍五入取整数 $c=msubstr($counter,0,($page-1)*2048); $c1=msubstr($counter,0,$page*2048); echo substr($c1,strlen($c),strlen($c1)-strlen($c)); }?> </td> </tr> <tr> <td> <table> <tr> <td> <span> 页次:<?php echo $page;?> / <?php echo $page_count;?> 页 </span> </td> <td> <span> 分页: <?php if($page!=1){ ?> <a href="#" onclick='return artpagination("test.php?page=1")'>首页</a> <a href="#" onclick='return artpagination("test.php?&page=<?php echo $page-1;?>")'>上一页</a> <?php } if($page<$page_count){ ?> <a href="#" onclick='return artpagination("test.php?page=<?php echo $page+1;?>")'>下一页</a> <a href="#" onclick='return artpagination("test.php?page=<?php echo $page_count;?>")'>尾页</a> <?php } ?> </span> </td> </tr> </table> </td> </tr> </table> </div> <script> //使用XMLHttpRequest对象创建异步HTTP请求 function artpagination(url){ //创建自定义函数,获取传递的参数 xmlHttp=new XMLHttpRequest(); xmlHttp.open('get',url,true); //根据传递的参数,通过get方法,执行另外一个实现分页功能的文件 xmlHttp.onreadystatechange = function(){ if(xmlHttp.readyState == 4 && xmlHttp.status == 200){ //将结果返回到div标签synopsis中 document.getElementById("synopsis").innerHTML = xmlHttp.responseText; } } xmlHttp.send(null); } </script>