2023年6月21日发(作者:)
PHPCMS v9自定义分页
概述:在v9二次开发中,经常会涉及到自定义分页样式的情况,默认的分页样式很难满足我们的开发要求。这个时候,就会用到自定义分页样式。
自定义分页样式需要用到以下两个文件:
V9安装目录/
V9安装目录/phpcms/libs/classes/template_
1)在V9安装目录/phpcms/libs/functions/autoload文件夹下创建一个 脚本文件。这个custom可以自己随便取,但是,必须是*.格式。
2)然后在文件里面找到pages()分页函数,将此函数复制到刚才创建的脚本中。然后将函数名改成custom_page,代码如下:
/**
* 自定义的函数脚本文件。
*
* 在phpcms/libs/autoload文件夹里面放置的*.这样的文件,会被自动加载。
* 切记,一定是*.这样的php脚本文件才会被自动加载,如果是类似这样的文件不会被加载。
* 在这个脚本里面写的任何函数,可以全局使用。在PHPCMS v9运行过程中,此脚本会被自动加载。
* 千万不要直接修改核心文件里面的功能,以免造成官方升级带来的代码错误问题。
*
* @author qljs888@
* @date 2012.05.27
*/
/**
* 自定义分页函数
*
* 这里定义的函数,请不要与系统核心里面定义的函数重名,否则会造成函数重复定义错误。
*
* @param $num 信息总数
* @param $curr_page 当前分页
* @param $perpage 每页显示数
* @param $urlrule URL规则
* @param $array 需要传递的数组,用于增加额外的方法
* @return 分页
*/
function custom_pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {
if(defined('URLRULE') && $urlrule == '') {
$urlrule = URLRULE;
$array = $GLOBALS['URL_ARRAY'];
} elseif($urlrule == '') { $urlrule = url_par('page={$page}');
}
$multipage = '';
if($num > $perpage) {
$page = $setpages+1;
$offset = ceil($setpages/2-1);
$pages = ceil($num / $perpage);
if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages);
$from = $curr_page - $offset;
$to = $curr_page + $offset;
$more = 0;
if($page >= $pages) {
$from = 2;
$to = $pages-1;
} else {
if($from <= 1) {
$to = $page-1;
$from = 2;
} elseif($to >= $pages) {
$from = $pages-($page-2);
$to = $pages-1;
}
$more = 1;
}
$multipage .= ''.$num.L('page_item').'';
if($curr_page>0) {
$multipage .= ' '.L('previous').'';
if($curr_page==1) {
$multipage .= ' 1';
} elseif($curr_page>6 && $more) {
$multipage .= ' 1..';
} else {
$multipage .= ' 1';
}
}
for($i = $from; $i <= $to; $i++) {
if($i != $curr_page) {
$multipage .= ' '.$i.'';
} else {
$multipage .= ' '.$i.'';
}
}
if($curr_page<$pages) {
$array).'" if($curr_page<$pages-5 && $more) {
$multipage .= ' ..'.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
} else {
$multipage .= ' '.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
}
} elseif($curr_page==$pages) {
$multipage .= ' '.$pages.' class="a1">'.L('next').'
} else {
$multipage .= ' '.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
}
}
return $multipage;
}
?>
3)因为我们都懂PHP,所以,里面涉及到的要添加什么HTML标签、样式什么的,这个应该很容易的。可以把需要实现的样式在这个函数里面添加进去,稍后的步骤会让其显示到模板里面。
4)打开 V9安装目录/phpcms/libs/classes/template_ 脚本文件,找到 pc_tag() 函数。
然后在函数里面搜索使用了系统分页函数的代码行,大概在207行。原代码如下:
$str .= '$pages = pages($'.$op.'_total, $page, $pagesize, $urlrule);';
修改为我们自定义的分页函数。修改之后的代码如下:
$str .= '$custom_pages = custom_pages($'.$op.'_total, $page, $pagesize, $urlrule);';
5)模板里面怎样调用分页输出的HTML代码?
v9默认调用的是{$pages}来输出,这个时候因为我们使用了自定义的函数,所以调用方式是:
{$custom_pages}
直接在模板里面调用这个变量就实现了。
6)当然如果使用过程中,发现SQL分页的不能正常使用,再在template_脚本文件中找到如下代码:
$str .= '$r = $get_db->sql_query("'.$sql.'");$s = $get_db->fetch_next();$pages=pages($s['count'],
$page, $pagesize, $urlrule);';
修改为如下:
$str .= '$r = $get_db->sql_query("'.$sql.'");$s
$get_db->fetch_next();$custom_pages=custom_pages($s['count'], $page, $pagesize, $urlrule);';
7)大功造成。祝你成功。
=
2023年6月21日发(作者:)
PHPCMS v9自定义分页
概述:在v9二次开发中,经常会涉及到自定义分页样式的情况,默认的分页样式很难满足我们的开发要求。这个时候,就会用到自定义分页样式。
自定义分页样式需要用到以下两个文件:
V9安装目录/
V9安装目录/phpcms/libs/classes/template_
1)在V9安装目录/phpcms/libs/functions/autoload文件夹下创建一个 脚本文件。这个custom可以自己随便取,但是,必须是*.格式。
2)然后在文件里面找到pages()分页函数,将此函数复制到刚才创建的脚本中。然后将函数名改成custom_page,代码如下:
/**
* 自定义的函数脚本文件。
*
* 在phpcms/libs/autoload文件夹里面放置的*.这样的文件,会被自动加载。
* 切记,一定是*.这样的php脚本文件才会被自动加载,如果是类似这样的文件不会被加载。
* 在这个脚本里面写的任何函数,可以全局使用。在PHPCMS v9运行过程中,此脚本会被自动加载。
* 千万不要直接修改核心文件里面的功能,以免造成官方升级带来的代码错误问题。
*
* @author qljs888@
* @date 2012.05.27
*/
/**
* 自定义分页函数
*
* 这里定义的函数,请不要与系统核心里面定义的函数重名,否则会造成函数重复定义错误。
*
* @param $num 信息总数
* @param $curr_page 当前分页
* @param $perpage 每页显示数
* @param $urlrule URL规则
* @param $array 需要传递的数组,用于增加额外的方法
* @return 分页
*/
function custom_pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {
if(defined('URLRULE') && $urlrule == '') {
$urlrule = URLRULE;
$array = $GLOBALS['URL_ARRAY'];
} elseif($urlrule == '') { $urlrule = url_par('page={$page}');
}
$multipage = '';
if($num > $perpage) {
$page = $setpages+1;
$offset = ceil($setpages/2-1);
$pages = ceil($num / $perpage);
if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages);
$from = $curr_page - $offset;
$to = $curr_page + $offset;
$more = 0;
if($page >= $pages) {
$from = 2;
$to = $pages-1;
} else {
if($from <= 1) {
$to = $page-1;
$from = 2;
} elseif($to >= $pages) {
$from = $pages-($page-2);
$to = $pages-1;
}
$more = 1;
}
$multipage .= ''.$num.L('page_item').'';
if($curr_page>0) {
$multipage .= ' '.L('previous').'';
if($curr_page==1) {
$multipage .= ' 1';
} elseif($curr_page>6 && $more) {
$multipage .= ' 1..';
} else {
$multipage .= ' 1';
}
}
for($i = $from; $i <= $to; $i++) {
if($i != $curr_page) {
$multipage .= ' '.$i.'';
} else {
$multipage .= ' '.$i.'';
}
}
if($curr_page<$pages) {
$array).'" if($curr_page<$pages-5 && $more) {
$multipage .= ' ..'.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
} else {
$multipage .= ' '.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
}
} elseif($curr_page==$pages) {
$multipage .= ' '.$pages.' class="a1">'.L('next').'
} else {
$multipage .= ' '.$pages.' href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'
}
}
return $multipage;
}
?>
3)因为我们都懂PHP,所以,里面涉及到的要添加什么HTML标签、样式什么的,这个应该很容易的。可以把需要实现的样式在这个函数里面添加进去,稍后的步骤会让其显示到模板里面。
4)打开 V9安装目录/phpcms/libs/classes/template_ 脚本文件,找到 pc_tag() 函数。
然后在函数里面搜索使用了系统分页函数的代码行,大概在207行。原代码如下:
$str .= '$pages = pages($'.$op.'_total, $page, $pagesize, $urlrule);';
修改为我们自定义的分页函数。修改之后的代码如下:
$str .= '$custom_pages = custom_pages($'.$op.'_total, $page, $pagesize, $urlrule);';
5)模板里面怎样调用分页输出的HTML代码?
v9默认调用的是{$pages}来输出,这个时候因为我们使用了自定义的函数,所以调用方式是:
{$custom_pages}
直接在模板里面调用这个变量就实现了。
6)当然如果使用过程中,发现SQL分页的不能正常使用,再在template_脚本文件中找到如下代码:
$str .= '$r = $get_db->sql_query("'.$sql.'");$s = $get_db->fetch_next();$pages=pages($s['count'],
$page, $pagesize, $urlrule);';
修改为如下:
$str .= '$r = $get_db->sql_query("'.$sql.'");$s
$get_db->fetch_next();$custom_pages=custom_pages($s['count'], $page, $pagesize, $urlrule);';
7)大功造成。祝你成功。
=
发布评论