分页原理
所谓分页显示,也就是讲数据库中的结果集,一段一段显示出来
怎么分段,当前在第几段 (每页有几条,当前再第几页)
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
分页公式:
(当前页数 - 1 )X 每页条数 , 每页条数
Select * from table limit ($Page- 1) * $PageSize, $PageSize
前面已经分享了30个代码片段,可以点击以下链接查看详细
1、PHP常用功能代码片段(1~5)
2、PHP常用功能代码片段(6~10)
3、PHP常用功能代码片段(11~15)
4、PHP常用功能代码片段(16~20)
5、PHP常用功能代码片段(21~25)
6、PHP常用功能代码片段(26~30)
今天是第7篇,主要用迭代实现数组的快速排序、实现下载图片的通用方法、实现人民币数字格式化,每三位加逗号、实现数据分页的通用方法、实现获取中文的首页字母方法,也就是第31到35这5个实用代码片段,希望可以帮到jquery学堂群里面的成员和广大对PHP开发的网友们提高开发效率。
31、PHP实现用迭代实现数组的快速排序
function quicksortX(&$seq)
{
$stack = array($seq);
$sort = array();
while ($stack) {
$arr = array_pop($stack);
if(count($arr) <= 1){
if (count($arr) == 1) {
$sort[] = &$arr[0];
}
continue;
}
$k = $arr[0];
$x = array();
$y = array();
$_size = count($arr);
for ($i = 1; $i < $_size; $i++) {
if ($arr[$i] <= $k) {
$x[] = &$arr[$i];
} else {
$y[] = &$arr[$i];
}
}
!empty($y) && array_push($stack, $y);
array_push($stack, array($arr[0]));
!empty($x) && array_push($stack, $x);
}
return $sort;
}
32、PHP实现下载图片的通用方法
function getPicture($url,$pictureName){
if ($url == "") return false;
//获取图片的扩展名
$info = getimagesize($url);
$mime = $info['mime'];
$type = substr(strrchr($mime,'/'), 1);
//不同的图片类型选择不同的图片生成和保存函数
switch($type){
case 'jpeg':
$img_create_func = 'imagecreatefromjpeg';
$img_save_func = 'imagejpeg';
$new_img_ext = 'jpg';
break;
case 'png':
$img_create_func = 'imagecreatefrompng';
$img_save_func = 'imagepng';
$new_img_ext = 'png';
break;
case 'bmp':
$img_create_func = 'imagecreatefrombmp';
$img_save_func = 'imagebmp';
$new_img_ext = 'bmp';
break;
case 'gif':
$img_create_func = 'imagecreatefromgif';
$img_save_func = 'imagegif';
$new_img_ext = 'gif';
break;
case 'vnd.wap.wbmp':
$img_create_func = 'imagecreatefromwbmp';
$img_save_func = 'imagewbmp';
$new_img_ext = 'bmp';
break;
case 'xbm':
$img_create_func = 'imagecreatefromxbm';
$img_save_func = 'imagexbm';
$new_img_ext = 'xbm';
break;
default:
$img_create_func = 'imagecreatefromjpeg';
$img_save_func = 'imagejpeg';
$new_img_ext = 'jpg';
}
if ($pictureName == ""){
$pictureName = time().".{$new_img_ext}";
}else{
$pictureName = $pictureName.".{$new_img_ext}";
}
$src_im = $img_create_func($url); //由url创建新图片
$img_save_func($src_im, $pictureName); //输出文件到文件
return $pictureName;
}
33、PHP实现人民币数字格式化,每三位加逗号
function num_format($num){
if(!is_numeric($num)){
return false;
}
$rvalue='';
$num = explode('.',$num);//把整数和小数分开
$rl = !isset($num['1']) ? '' : $num['1'];//小数部分的值
$j = strlen($num[0]) % 3;//整数有多少位
$sl = substr($num[0], 0, $j);//前面不满三位的数取出来
$sr = substr($num[0], $j);//后面的满三位的数取出来
$i = 0;
while($i <= strlen($sr)){
$rvalue = $rvalue.','.substr($sr, $i, 3);//三位三位取出再合并,按逗号隔开
$i = $i + 3;
}
$rvalue = $sl.$rvalue;
$rvalue = substr($rvalue,0,strlen($rvalue)-1);//去掉最后一个逗号
$rvalue = explode(',',$rvalue);//分解成数组
if($rvalue[0]==0){
array_shift($rvalue);//如果第一个元素为0,删除第一个元素
}
$rv = $rvalue[0];//前面不满三位的数
for($i = 1; $i < count($rvalue); $i++){
$rv = $rv.','.$rvalue[$i];
}
if(!empty($rl)){
$rvalue = $rv.'.'.$rl;//小数不为空,整数和小数合并
}else{
$rvalue = $rv;//小数为空,只有整数
}
return $rvalue;
}
34、PHP实现数据分页的通用方法
function show_page($count,$page,$page_size)
{
$page_count = ceil($count/$page_size); //计算得出总页数
$init=1;
$page_len=7;
$max_p=$page_count;
$pages=$page_count;
//判断当前页码
$page=(empty($page)||$page<0)?1:$page;
//获取当前页url
$url = $_SERVER['REQUEST_URI'];
//去掉url中原先的page参数以便加入新的page参数
$parsedurl=parse_url($url);
$url_query = isset($parsedurl['query']) ? $parsedurl['query']:'';
if($url_query != ''){
$url_query = preg_replace("/(^|&)page=$page/",'',$url_query);
$url = str_replace($parsedurl['query'],$url_query,$url);
if($url_query != ''){
$url .= '&';
}
} else {
$url .= '?';
}
//分页功能代码
$page_len = ($page_len%2)?$page_len:$page_len+1; //页码个数
$pageoffset = ($page_len-1)/2; //页码个数左右偏移量
$navs='';
if($pages != 0){
if($page!=1){
$navs.="<a href=\"".$url."page=1\">首页</a> "; //第一页
$navs.="<a href=\"".$url."page=".($page-1)."\">上页</a>"; //上一页
} else {
$navs .= "<span class='disabled'>首页</span>";
$navs .= "<span class='disabled'>上页</span>";
}
if($pages>$page_len)
{
//如果当前页小于等于左偏移
if($page<=$pageoffset){
$init=1;
$max_p = $page_len;
}
else //如果当前页大于左偏移
{
//如果当前页码右偏移超出最大分页数
if($page+$pageoffset>=$pages+1){
$init = $pages-$page_len+1;
}
else
{
//左右偏移都存在时的计算
$init = $page-$pageoffset;
$max_p = $page+$pageoffset;
}
}
}
for($i=$init;$i<=$max_p;$i++)
{
if($i==$page){$navs.="<span class='current'>".$i.'</span>';}
else {$navs.=" <a href=\"".$url."page=".$i."\">".$i."</a>";}
}
if($page!=$pages)
{
$navs.=" <a href=\"".$url."page=".($page+1)."\">下页</a> ";//下一页
$navs.="<a href=\"".$url."page=".$pages."\">末页</a>"; //最后一页
} else {
$navs .= "<span class='disabled'>下页</span>";
$navs .= "<span class='disabled'>末页</span>";
}
echo "$navs";
}
}
35、PHP实现获取中文的首页字母方法
function getfirstchar($s0) {
$fchar = ord(substr($s0, 0, 1));
if (($fchar >= ord("a") and $fchar <= ord("z"))or($fchar >= ord("A") and $fchar <= ord("Z"))) return strtoupper(chr($fchar));
$s = iconv("UTF-8", "gb2312", $s0);
$asc = ord($s{0}) * 256 + ord($s{1})-65536;
if ($asc >= -20319 and $asc <= -20284)return "A";
if ($asc >= -20283 and $asc <= -19776)return "B";
if ($asc >= -19775 and $asc <= -19219)return "C";
if ($asc >= -19218 and $asc <= -18711)return "D";
if ($asc >= -18710 and $asc <= -18527)return "E";
if ($asc >= -18526 and $asc <= -18240)return "F";
if ($asc >= -18239 and $asc <= -17923)return "G";
if ($asc >= -17922 and $asc <= -17418)return "I";
if ($asc >= -17417 and $asc <= -16475)return "J";
if ($asc >= -16474 and $asc <= -16213)return "K";
if ($asc >= -16212 and $asc <= -15641)return "L";
if ($asc >= -15640 and $asc <= -15166)return "M";
if ($asc >= -15165 and $asc <= -14923)return "N";
if ($asc >= -14922 and $asc <= -14915)return "O";
if ($asc >= -14914 and $asc <= -14631)return "P";
if ($asc >= -14630 and $asc <= -14150)return "Q";
if ($asc >= -14149 and $asc <= -14091)return "R";
if ($asc >= -14090 and $asc <= -13319)return "S";
if ($asc >= -13318 and $asc <= -12839)return "T";
if ($asc >= -12838 and $asc <= -12557)return "W";
if ($asc >= -12556 and $asc <= -11848)return "X";
if ($asc >= -11847 and $asc <= -11056)return "Y";
if ($asc >= -11055 and $asc <= -10247)return "Z";
return null;
}
如果您觉得本文的内容对您的学习有所帮助:
关键字:
jquery