SQL类路径:include/dedesql.class.php
$dsql->SetQuery($sql);//将SQL查询语句格式化
$dsql->Execute();
$dsql->GetOne()
{dede:php}
$cid = 0;//父类id(家装、工装、建筑)
$list_id = '';//当前子栏目ID,如果没选择则为'',即父类下所有子类
/*
前提:必须知道父类$cid(无论当前是哪个栏目),这样才能循环出子类1、子类2
目前只有两种形式会展示该列表页:
1、父类(即 家装、工装等大类 或 VR家装、VR工装)点击时,这时循环 大类下的 子类1(风格)-》子类2(欧式、中式)
2、子类2(即 欧式、中式)点击时。
这时需要获取 子类1的ID,再获取父类ID。即满足了前提条件。
*/
//(父类id)作品全集:$reid=2, VR全景$reid=3
$reid = $refObj-> Fields['reid'];
if(in_array($reid, array(2, 3))) {
$cid = $refObj-> Fields['id'];
$sql = 'select id from dede_arctype where reid in (select id from dede_arctype where reid='.$refObj-> Fields['id'].') ';
$dsql->SetQuery($sql);//将SQL查询语句格式化
$dsql->Execute();//执行SQL操作
//通过循环输出执行查询中的结果
while($row = $dsql->GetArray()){
$list_id = $list_id.$row['id'].',';
}
$list_id = rtrim($list_id, ",");//选择大类时(家装、工装)
}else{
$row = $dsql->GetOne('select reid from dede_arctype where id='.$reid);
$cid = $row['reid'];
$list_id = $refObj-> Fields['id'];//选择子类时(现代简约)
}
//echo $cid.'====='.$list_id.'---';
//print_r($refObj-> Fields);
//----------------------------栏目筛选-------------------------------
$list_array = array();//栏目数组 array(id1=>row, id2=>row)
$sql = 'select * from dede_arctype where reid='.$cid;
$dsql->SetQuery($sql);//将SQL查询语句格式化
$dsql->Execute();//执行SQL操作
//通过循环输出执行查询中的结果
while($row = $dsql->GetArray()){
echo '<ul class="clearfix">';
echo '<li class="li01">'.$row['typename'].'</li>';
echo '<li><a href="/plus/list.php?tid='.$cid.'">不限</a></li>';
$sql2 = 'select * from dede_arctype where reid='.$row['id'];
$dsql->SetQuery($sql2);//将SQL查询语句格式化
$dsql->Execute(2);//执行SQL操作
//通过循环输出执行查询中的结果
while($row2 = $dsql->GetArray(2)){
$class = '';
if($list_id == $row2['id']) $class = ' class="current"';
echo '<li '.$class.'><a href="/plus/list.php?tid='.$row2['id'].'">'.$row2['typename'].'</a></li>';
$list_array[$row2['id']] = $row2;
}
echo '</ul>';
}
//echo $sql.'---';
//----------------------------搜索------------------------------
echo '
<div class="search clearfix" style="display:none;">
<form class="clearfix" action="" method="get" target="_blank" onsubmit="">
<input type="search" name="search_keyword" class="txt" placeholder="请输入查询关键字" >
<input type="hidden" name="class_id" value="102101"/>
<input type="submit" name="submit" class="btn" value="搜索">
</form>
<p>热门搜索:
<a href="case.php?search_keyword=平层&class_id=102101">平层</a>
<a href="case.php?search_keyword=新中式&class_id=102101">新中式</a>
</p>
</div>
</div>
</div>
';
//----------------------------列表-------------------------------
echo '<div class="clear"></div>';
echo '<div class="case">';
echo '<div class="wrap">';
echo '<ul class="clearfix">';
$limit = 12;//每页几条
$page = isset($_GET['page']) ? (int)$_GET['page'] : 0;//当前页数
$limita = ($page<=1) ? 0 : ($limit * $page);
if($page < 1) $page = 1;
$show_page = 5;//显示几个分页
//总条数
$row = $dsql->GetOne('select COUNT(*) AS counts from dede_archives where typeid in ('.$list_id.') ');
$count = $row['counts'];
$sql = 'select * from dede_archives where typeid in ('.$list_id.') LIMIT '.$limita.', '.$limit.' ';
$dsql->SetQuery($sql);//将SQL查询语句格式化
$dsql->Execute();//执行SQL操作
//通过循环输出执行查询中的结果
while($row = $dsql->GetArray()){
echo ' <li><a href="'.$list_array[$row['typeid']]['typedir'].'/'.$row['id'].'.html"><img src="'.$row['litpic'].'" width="355" height="265" /><span>'.$row['title'].'</span></a></li>';
}
echo '</ul>';
echo '</div>';
echo '</div>';
//print_r($list_array);
//----------------------------分页-------------------------------
$p=new Page($count,$show_pag,$page,$limit);
//$p=new Page(1000, 5, 10, 10);
//print_r($p->getPages()); //生成一个页码数组(键为页码,值为链接)
echo ' <div class="page">';
echo ' <span>';
echo $p->showPages(1); //生成一个页码样式(可添加自定义样
echo '</span> ';
echo '</div> ';
/**
* 分页类
*
* 调用方式:
* $p=new Page(总条数,显示页数,当前页码,每页显示条数,[链接]);
* print_r($p->getPages()); //生成一个页码数组(键为页码,值为链接)
* echo $p->showPages(1); //生成一个页码样式(可添加自定义样式)
*
* @author: Dzer <Email:358654744@qq.com Blog:Dzer.me>
* @version: 2014-12-25 09:09:42
* @Last Modified time: 2014-12-28 17:37:13
*/
/*
思路:
给我一个 总页数,需要显示的页数,当前页,每页显示的条数,连接
写一个方法 生成一个一维数组,键为页码 值为连接
写一个方法 返回一个生成好样式的页码(并且可以根据自己需要添加样式)
默认样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
*/
class Page{
protected $count; //总条数
protected $showPages; //需要显示的页数
protected $countPages; //总页数
protected $currPage; //当前页
protected $subPages; //每页显示条数
protected $href; //连接
protected $page_arr=array(); //保存生成的页码 键页码 值为连接
/**
* __construct 构造函数(获取分页所需参数)
* @param int $count 总条数
* @param int $showPages 显示页数
* @param int $currPage 当前页数
* @param int $subPages 每页显示数量
* @param string $href 连接(不设置则获取当前URL)
*/
public function __construct($count,$showPages,$currPage,$subPages,$href=''){
$this->count=$count;
$this->showPages=$showPages;
$this->currPage=$currPage;
$this->subPages=$subPages;
//如果链接没有设置则获取当前连接
if(empty($href)){
$this->href=htmlentities($_SERVER['PHP_SELF']);
}else{
$this->href=$href;
}
$this->construct_Pages();
}
/**
* getPages 返回页码数组
* @return array 一维数组 键为页码 值为链接
*/
public function getPages(){
return $this->page_arr;
}
/**
* showPages 返回生成好的页码
* @param int $style 样式
* @return string 生成好的页码
*/
public function showPages($style=1){
$func='pageStyle'.$style;
return $this->$func();
}
/**
* pageStyle1 分页样式(可参照这个添加自定义样式 例如pageStyle2())
* 样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
* @return string
*/
protected function pageStyle1(){
/* 构造普通模式的分页
共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [1] [2] [3] .. [下页] [尾页]
*/
//$pageStr='共'.$this->count.'条记录,每页显示'.$this->subPages.'条';
//$pageStr.='当前第'.$this->currPage.'/'.$this->countPages.'页 ';
$_GET['page'] = 1;
$pageStr.='<a href="'.$this->href.'?'.http_build_query($_GET).'">首页</a> ';
//如果当前页不是第一页就显示上页
if($this->currPage>1){
$_GET['page'] = $this->currPage-1;
$pageStr.='<a href="'.$this->href.'?'.http_build_query($_GET).'">上页</a> ';
}
foreach ($this->page_arr as $k => $v) {
$_GET['page'] = $k;
$pageStr.='<a href="'.$v.'">'.$k.'</a>  ';
}
//如果当前页小于总页数就显示下一页
if($this->currPage<$this->countPages){
$_GET['page'] = $this->currPage+1;
$pageStr.='<a href="'.$this->href.'?'.http_build_query($_GET).'">下页</a>  ';
}
$_GET['page'] = $this->countPages;
$pageStr.='<a href="'.$this->href.'?'.http_build_query($_GET).'">尾页</a>  ';
return $pageStr;
}
/**
* construct_Pages 生成页码数组
* 键为页码,值为链接
* $this->page_arr=Array(
* [1] => index.php?page=1
* [2] => index.php?page=2
* [3] => index.php?page=3
* ......)
*/
protected function construct_Pages(){
//计算总页数
$this->countPages=ceil($this->count/$this->subPages);
//根据当前页计算前后页数
$leftPage_num=floor($this->showPages/2);
$rightPage_num=$this->showPages-$leftPage_num;
//左边显示数为当前页减左边该显示的数 例如总显示7页 当前页是5 左边最小为5-3 右边为5+3
$left=$this->currPage-$leftPage_num;
$left=max($left,1); //左边最小不能小于1
$right=$left+$this->showPages-1; //左边加显示页数减1就是右边显示数
$right=min($right,$this->countPages); //右边最大不能大于总页数
$left=max($right-$this->showPages+1,1); //确定右边再计算左边,必须二次计算
for ($i=$left; $i <= $right; $i++) {
$_GET['page'] = $i;
$this->page_arr[$i]=$this->href.'?'.http_build_query($_GET);
}
}
}
{/dede:php}