PhpcmsV9调用全站最新文章的方法 小编亲测完美好用

今天有客户想实现PhpcmsV9调用全站最新文章,不过PHPCMS默认是没有这个功能的,只能调用某个频道或栏目的最新文章,只要是跨模型就不行了,齐鲁建站小编经过研究发现Phpcms调用全站文章的方法,亲测完美好用。

下面就来说说Phpcms调用全站文章的方法。

第一步:需要修改文件:\phpcms\modules\content\classes\content_tag.class.php,找到以下函数

/*** 列表页标签* @param $data*/public function lists($data) {$catid = intval($data['catid']);if(!$this->set_modelid($catid)) return false;if(isset($data['where'])) {$sql = $data['where'];} else {$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';if($this->category[$catid]['child']) {$catids_str = $this->category[$catid]['arrchildid'];$pos = strpos($catids_str,',')+1;$catids_str = substr($catids_str, $pos);$sql = "status=99 AND catid IN ($catids_str)".$thumb;} else {$sql = "status=99 AND catid='$catid'".$thumb;}}$order = $data['order'];$return = $this->db->select($sql, '*', $data['limit'], $order, '', 'id');//调用副表的数据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])) $return[$k] = array_merge($v, $return[$k]);}}}}return $return;}

修改为:

/*** 列表页标签* @param $data*/public function lists($data) {$catid = intval($data['catid']);if(isset($data['where'])) {$sql = $data['where'];} else {$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';if(!empty($catid)) {if(!$this->set_modelid($catid)) return false;if($this->category[$catid]['child']) {$catids_str = $this->category[$catid]['arrchildid'];$pos = strpos($catids_str,',')+1;$catids_str = substr($catids_str, $pos);$sql = "status=99 AND catid IN ($catids_str)".$thumb;} else {$sql = "status=99 AND catid='$catid'".$thumb;}}else {$sql = "status=99".$thumb;}}$order = $data['order'];$return = $this->db->select($sql, '*', $data['limit'], $order, '', 'id');//调用副表的数据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])) $return[$k] = array_merge($v, $return[$k]);}}}}return $return;}

第二步:修改代码后,即能调取全站最新文章。调用方法:

{pc:content action="lists" num="10" order="id DESC" cache="3600"}

以上就是关于Phpcms调用全站文章的所有内容,不懂的可以找小编聊聊哦。

极客网企业会员

免责声明:本网站内容主要来自原创、合作伙伴供稿和第三方自媒体作者投稿,凡在本网站出现的信息,均仅供参考。本网站将尽力确保所提供信息的准确性及可靠性,但不保证有关资料的准确性及可靠性,读者在使用前请进一步核实,并对任何自主决定的行为负责。本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。任何单位或个人认为本网站中的网页或链接内容可能涉嫌侵犯其知识产权或存在不实内容时,应及时向本网站提出书面权利通知或不实情况说明,并提供身份证明、权属证明及详细侵权或不实情况证明。本网站在收到上述法律文件后,将会依法尽快联系相关文章源头核实,沟通删除相关内容或断开相关链接。