phpcms v9中的page分面函数怎么理解呀

2024-11-15 22:26:12
推荐回答(3个)
回答1:

使用过Phpcms V9的朋友,肯定知道PC V9默认的Page页面是只有一篇内容的,但是一旦添加了子栏目,那么父级Page栏目就会不能添加内容,这样就会出现问题:当访问父级栏目的时候,默认不会转到最新page或者某一个子栏目页面,这样会发现没有内容。于是需要自定义Phpcms V9列表页调用栏目第一篇文章内容,在此分享另外一种方法做到父单页栏目添加内容方法,这是PC V9鲜为人知的Page模型自定义的方法。

具体修改模型conten文件phpcms\modules\content\content.php,方法是修改init方法
第一步:通过init我找到了public_categorys函数 直接定位到约514行。
就是下面这段代码:
$strs="\$add_icon\$catname";
$strs2 = "\$catname";
将其中的
$strs2 = "\$catname";
替换为:
$strs2= "\$add_icon\$catname";
修改后保存。这样让page能够修改这些栏目以及里面的内容,之后进行更新缓存、url更新,以及内容页更新等操作。
第二步:修改create_html.php,之后更新
修改content.php同文件夹下的create_html.php,找到178行

//$r['disabled'] = $r['child'] ? 'disabled' : '';
这一行去掉。
然后进后台更新缓存,可以编辑单页page父栏目了。

回答2:

图像是已经存在的图像
目标图像是添加水印时生成的图像, $w_pos = 0;)

另外
$image->', $target = 'watermark_img'.($info['#ff0000'watermark_img']), $w_text = ';', $w_font = 5,目标图像不赋值, $w_color = ''**
* 添加水印
*
* @param string $source 源图像地址 (需要加水印的图像)
* @param string $target 目标图像地址; 中$savefile相同;;] , $w_img = ',目标图像)? $info[',默认情况下;watermark($savefile, $savefile),即用源图像本身生产目标图像
水印图片是$w_img这个
默认情况下水印图片为;] ;watermark_img'/,$w_img=PHPCMS_ROOT,默认为源图像的地址
* @param int $w_pos 添加水印的位置
* @param string $w_img 水印图像
* @param string $w_text 要添加的文字
* @param int $w_font 字体大小
* @param string $w_color 字体颜色
* @return bool
*/: $PHPCMS['
function watermark($source;;watermark(源图像,添加水印后的图像就是没加水印前的图像
$image->

回答3:

网站栏目页及列表页要实现的效果如下:
1、栏目页最多只列出100页;
2、列表页不限制最大页数,有多少页就列出多少页。
要实现这个效果,需要改动的文件有3个,文件及改动内容如下:

复制代码代码如下:
/*
文件:/include/global.func.php
函数:get
*/
/*
为 get 函数添加一个参数
ismaxpage 就是所添加的参数,用于判断是否启用“列表页最大页数”这个参数
而插入代码的部分是为了改变total的值,即记录集总数
*/
function get($sql, $rows = 0, $page = 0, $dbname = '', $dbsource = '', $urlrule = '', $distinct_field = '', $catid = 0, $ismaxpage = 0) {
...
if($dbname || $dbsource)
{
$r = $db->get_one("SELECT COUNT(*) AS `count` ".stristr($sql, 'from'));
$total = $r['count'];
}
elseif($distinct_field)
{
$total = cache_count("SELECT COUNT(distinct $distinct_field) AS `count` ".stristr($sql, 'from'));
}
else
{
$total = cache_count("SELECT COUNT(*) AS `count` ".stristr($sql, 'from'));
}
/* 插入以下代码 开始 */
global $PHPCMS;
if ($ismaxpage) {
$total = min($total, $PHPCMS['maxpage']*$rows);
}
/* 插入以上代码 结束 */
$pages = pages($total, $page, $rows, $urlrule, '', $catid);
...
}

复制代码代码如下:
/*
文件:/include/template.func.php
函数:get_parse
*/
/*
前台 get 标签最后是转换成 get 函数,以下是处理 get 标签的函数
因为 get 函数增加了一个参数 $ismaxpage,所以这里也需要做相应修改
以下是修改后的部分代码
*/
function get_parse($str)
{
...
extract($r);
if(!isset($dbsource)) $dbsource = '';
if(!isset($dbname)) $dbname = '';
if(!isset($sql)) $sql = '';
if(!isset($rows)) $rows = 0;
if(!isset($urlrule)) $urlrule = '';
if(!isset($catid)) $catid = 0;
if(!isset($distinctfield)) $distinctfield = '';
if(!isset($return) || !preg_match("/^\w+$/i", $return)) $return = 'r';
if(!isset($ismaxpage)) $ismaxpage = 0; /* 增加部分 */
if(isset($page))
{
/* 修改部分,增加了 $ismaxpage 这个参数,仔细看 */
$str = "\${$return}){\$n++;?>";
}
...
}

复制代码代码如下:
/*
文件:/admin/html.inc.php
*/
/* 找到以下代码 */
if($CATEGORY[$catid]['child'])
{
$pages = 1;
$html->category($catid);
}
else
{
$offset = $pagesize*($page-1);
if($page == 1)
{
$contents = cache_count("SELECT COUNT(*) AS `count` FROM `".DB_PRE."content` WHERE catid=$catid AND status=99");
$total = ceil($contents/$PHPCMS['pagesize']);
$pages = ceil($total/$pagesize);
}
$max = min($offset+$pagesize, $total);
for($i=$offset; $i<=$max; $i++)
{
$html->category($catid, $i);
}
}
/* 然后把上面的代码替换成以下的代码 */
$offset = $pagesize*($page-1);
if($page == 1)
{
$condition=get_sql_catid($catid);
$contents = cache_count("SELECT COUNT(*) AS `count` FROM `".DB_PRE."content` WHERE status=99 $condition");
$total = ceil($contents/$PHPCMS['pagesize'])+1;
/* 以下这行代码确保了生成的栏目及列表页的数量是正确的,该生成多少页就是多少页 */
$total = $CATEGORY[$catid]['child'] ? min($total, $PHPCMS['maxpage']+1) : $total;
$pages = ceil($total/$pagesize);
}
$max = min($offset+$pagesize, $total);
for($i=$offset; $i<$max; $i++)
{
$html->category($catid, $i);
}

以下是一个栏目页及列表页模板的示例

复制代码代码如下:
$catids = str_replace('`catid`', 'a.`catid`', get_sql_catid($catid));
$sql = "
SELECT a.contentid, a.catid, a.title, a.keywords, a.thumb, a.userid, a.updatetime, a.inputtime, a.islink, a.url, a.style
FROM `phpcms_content` a
WHERE a.status=99 $catids ORDER BY a.contentid DESC";
/* 判断是否有子栏目,有的话就开启“列表页最大页数”这个参数,限制栏目页页数 */
if ($child) {
$ismaxpage = 1;
$page = min($page, $PHPCMS['maxpage']); /* 为了防止在地址栏输入页数,这里是要滴 */
}
?>


    {get sql="$sql" rows="20" page="$page" catid="$catid" ismaxpage="$ismaxpage"}
  • {$r[title]}

  • {/get}

{$pages}


经过以上这么一翻捣鼓,一开始的那效果就出来了。基本思路就是先要为get标签增加一个参数,用于判断是否开启“列表页最大页数”,然后生成静态页面的时候限制一下栏目页,不然它有多少生成多少。
PHPCMS 确实挺好,但需要改进的地方同样也很多,很多细节都没处理好,而有些功能都不是给人用的。希望 PHPCMS 能越来越强大!

详细出处参考:http://www.jb51.net/cms/38713.html