查看: 33|回覆: 0

[教程] phpcms 调用全站任何模型数据的PC标签

[複製鏈接]

3

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2010-4-23
發表於 2023-7-10 00:00:00 | 顯示全部樓層 |閲讀模式

首先打开

\phpcms\modules\content\classes\content_tag.class.php

添加如下代码

 

代码如下:


/**
* 列表页标签 所有模型,
* @param $data
*/
public function allmodel($data) {
$this->model = getcache('model', 'commons');
$datas=array();</p> <p>foreach($this->model as $key => $val){
$this->db->set_model($val['modelid']);
if(isset($data['where'])) {
$sql = $data['where'];
} else {
$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';
$sql = "status=99 ".$thumb;</p> <p>}
$order = $data['order'];</p> <p>$return = $this->db->select($sql, '*', $data['limit'], $order, '', 'id');</p> <p>//调用副表的数据
if (isset($data['moreinfo']) && intval($data['moreinfo']) == 1) {
$ids = array();
foreach ($return as $v) {
if (isset($v['id']) && !empty($v['id'])) {
$ids[] = $v['id'];
} else {
continue;
}
}
if (!empty($ids)) {
$this->db->table_name = $this->db->table_name.'_data';
$ids = implode('\',\'', $ids);
$r = $this->db->select("`id` IN ('$ids')", '*', '', '', '', 'id');
if (!empty($r)) {
foreach ($r as $k=>$v) {
if (isset($return[$k])) $datas[]=$return[$k]= array_merge($v, $return[$k]);</p> <p>}
}
}
}
};</p> <p>return $datas;
}


 

 

下面是调用方法

在页面上使用PC标签,完整示范如下

 

代码如下:


//参数请参考PC原有参数,记住,moreinfo 必须带上, num 数量也不是总数量,而是每个模型的调取最大值。
{pc:content action="allmodel" where="$where" thumb="1" num="6" order="id DESC" moreinfo="1"}
{loop $data $r}
<li> <a href=""></a></li>
{/loop}
{/pc}
回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部