phpcms v9 调用全站热门文章
来源:互联网 发布:java in是什么意思啊 编辑:程序博客网 时间:2024/05/24 07:18
此问题需要添加一个标签,找到phpcms/modules/content/classes/content_tag.class.php,可以在最后添加这个function。
function sitehits($data){
if(empty($data['siteid'])) $data['siteid']=1;
$siteid = intval($data['siteid']);
$this->hits_db =pc_base::load_model('hits_model');
$category_content = getcache('category_content','commons');
$catid = '';
//获取站点下所有栏目ID
foreach($category_content as $key=>$val){
if($val==$siteid){
$catid .= $comma.$key;
$comma=',';
}
}
$sql='catid in('.$catid.')';
if(isset($data['day'])) {
$updatetime = SYS_TIME-intval($data['day'])*86400;
$sql .= " AND updatetime>'$updatetime'";
}
//获取点击排行
$r =$this->hits_db->select($sql,'hitsid',$data['limit'],$data['order']);
$return = array();
$sitemodel_model_db = pc_base::load_model('sitemodel_model');
$this->db_config =pc_base::load_config('database');
$tablepre =$this->db_config['default']['tablepre'];
foreach($r as $key){
preg_match_all('/-(d+)-/',$key['hitsid'],$modelid);
$id =substr($key['hitsid'],(strpos($key['hitsid'],'-',2)+1));
$tablename =$sitemodel_model_db->get_one(array('modelid'=>$modelid[1][0]),'tablename');
$this->db->table_name =$tablepre.$tablename['tablename'];
$return[] =array_merge($return,$this->db->get_one(array('id'=>$id)));
}
return $return;
}
这样就好了,下面看看调用的代码吧
{pc:content action="sitehits" siteid="1" num="10" day="7"order="views DESC" cache="3600"}
{loop $data $r}
<li><ahref="{$r[url]}"target="_blank">{$r[title]}</a></li>
{/loop}
{/pc}
用get标签,直接去读取数据库,我读取了news,category这两上表,但他们有相同的变量名,所以用as将它改为新变量名,这样可以实现两个链接,分别链接到栏目所在的列表,和文章内容页。
用H标签而不用li标签,是为了增强SEO,加一个cache,这样可以减少数据库的压力。
{pc:get sql="SELECT a.title, a.catid, b.catid, b.catname,a.url as turl ,b.url as curl, a.id FROM `v9_news` a, `v9_category`b WHERE a.catid = b.catid ORDER BY `a`.`id` DESC " num="12"cache="300"}
{loop $data $r}
<h5><fontclass="cate"><ahref="{$r[curl]}">[{$r[catname]}]</a></font><aclass="gray" href="{$r[turl]}"title="{$r[title]}">{str_cut($r['title'],45)}</a></h5>{/loop}
{/pc}
- phpcms v9 调用全站热门文章
- PHPCMS V9调用全站数据
- 【phpcms-v9】phpcms-v9中get标签调用全站文章内容
- Phpcms V9 调用全站最新文章的代码
- Phpcms V9 调用全站最新文章的方法
- PHPCMS V9 全站调用会员信息代码
- phpcms v9不限模型全站搜索
- phpcms v9调用全站最新文章(最近更新所有内容)
- phpcms v9 调用方法全站点击排行
- phpcms v9笔记之全站点击排行调用方法
- PHPCMS V9调用栏目
- 【phpcms-v9】如何通过{pc}标签获取全站文章内容?
- PHPCMS V9 全站通用日期时间标签
- PHPCMS V9类调用方法
- 【phpcms-v9】phpcms-v9中联动菜单的调用
- Phpcms V9 后台实现全栏目搜索
- phpcms v9 调用编辑器的方法
- phpcms v9联动菜单前台列表调用
- 《春秋争霸》
- win7下matlab配置vlfeat
- 侧拉菜单(SlidingMenu)
- 迷宫问题(广度优先搜索,输出最短路径)
- Linux基础知识笔记(三)
- phpcms v9 调用全站热门文章
- servlet
- 使用KMS激活后浏览器主页打开是T999.cn
- MyBatis原始Dao开发方式
- LeetCode-52-N-Queens II 同前一题
- 第三周实践项目1(2)--顺序表的基本运算插入.删除数据,初始化.销毁线性表
- 动态创建Fragment与TextView配合PullToRefresh刷新json串左右滑动
- 函数指针与指针函数
- 其他-jxl的使用(操作excel表格)