文档章节

ecshop 分页增加自定义参数,以投票页面为例

越野小生
 越野小生
发布于 2016/06/16 20:48
字数 496
阅读 18
收藏 0

比如投票页面增加parent_id,order可以这样做

在根目录中建立voting_list.php文件,里面内容为

<?php
define('IN_ECS', true);

require(dirname(__FILE__) . '/includes/init.php');

if ((DEBUG_MODE & 2) != 2)
{
    $smarty->caching = true;
}

/* 清除缓存 */
clear_cache_files();

/*------------------------------------------------------ */
//-- INPUT
/*------------------------------------------------------ */

/* 获得指定的分类ID */
$parent_id   = !empty($_REQUEST['parent_id'])  ? intval($_REQUEST['parent_id'])  : 0;
/* 获得当前页码 */
$page   = !empty($_REQUEST['page'])  && intval($_REQUEST['page'])  > 0 ? intval($_REQUEST['page'])  : 1;

/*------------------------------------------------------ */
//-- PROCESSOR
/*------------------------------------------------------ */

/* 获得页面的缓存ID */
$cache_id = sprintf('%X', crc32( 'voting_list-' . $page . '-' . $_CFG['lang']));

if (!$smarty->is_cached('voting_list.dwt', $cache_id))
{
    /* 如果页面没有被缓存则重新获得页面的内容 */

    assign_template();
$position =assign_ur_here();
    $smarty->assign('page_title',           $position['title']);     // 页面标题
    $smarty->assign('ur_here',              $position['ur_here']);   // 当前位置
$smarty->assign('keywords',    htmlspecialchars($_CFG['shop_keywords']));  
$smarty->assign('description',  htmlspecialchars($_CFG['shop_desc']));
    /* 获得文章总数 */
	
	
	
    $size  =1;
    $count = $db->getOne("SELECT COUNT(*) FROM " .$ecs->table('voting'). " WHERE status = 0 and parent_id=".$parent_id);
	
    $pages  = ($count > 0) ? ceil($count / $size) : 1;
	//总页面数量

    // if ($page > $pages)
    // {
        // $page = $pages;
    // }

    /* 获得文章列表 */

if(intval($_REQUEST['sort']) == 0){
		$orderby=" ORDER BY voting_id DESC";
	$sort=0;
	 }else{
		$orderby=" ORDER BY voting_num DESC";
	$sort=1; }
	

    //增加搜索条件,如果有搜索内容就进行搜索    
        
        $sql = 'SELECT * FROM ' .$GLOBALS['ecs']->table('voting') .
               ' WHERE status =0 and parent_id='.$parent_id.$orderby;
 
/* 仿真 Adodb 函数 function selectLimit($sql, $num, $start = 0) */
   
    $res = $GLOBALS['db']->selectLimit($sql, $size, ($page-1) * $size);
	
	
    $arr = array();
    if ($res)
    {
        while ($row = $GLOBALS['db']->fetchRow($res))
        {
            $voting_id = $row['voting_id'];
$arr[$voting_id]['parent_id']          = $parent_id;
            $arr[$voting_id]['id']          = $voting_id;
            $arr[$voting_id]['title']       = $row['title'];
			$arr[$voting_id]['voting_num']       = $row['voting_num'];
$arr[$voting_id]['cover_img']    = $row['cover_img'];


   $arr[$voting_id]['url']  = build_uri('voting_list', array('id'=>$voting_id,'parent_id'=>$parent_id), $row['title']) ;//生成具体的内容链接,还要修改includes/lib_common.php 中的build_uri()
  $arr[$voting_id]['add_time']    = date($GLOBALS['_CFG']['date_format'], $row['add_time']);
        }
		
    }
	

    $smarty->assign('voting_list',$arr);
	$pager = get_pager('voting_list.php', array('sort'=>$sort,'parent_id'=>$parent_id), $count, $page, $size);
  $smarty->assign('pager', $pager);
  //上面两行是分页.
  
}

$smarty->display('voting_list.dwt', $cache_id);


?>

如果还需要自动生成内容页的url,还要修改includes/lib_common.php 中的build_uri()函数.

增加

 case 'voting_list':
                if ($rewrite)
                {
                    $uri = 'voting_list';
                    if (!empty($page))
                    {
                        $uri .= '-' . $page;
                    }
                    if (!empty($sort))
                    {
                        $uri .= '-' . $sort;
                    }
                    if (!empty($order))
                    {
                        $uri .= '-' . $order;
                    }
                    if (!empty($keywords))
                    {
                        $uri .= '-' . $keywords;
                    }
                }
                else
                {
                    $uri = 'voting_list.php?id='.$id.'&amp;parent_id='.$parent_id;
                    if (!empty($page))
                    {
						
                        $uri .= 'page=' . $page;
                    }
                    if (!empty($sort))
                    {
                        $uri .= '&amp;sort=' . $sort;
                    }
                    if (!empty($order))
                    {
                        $uri .= '&amp;order=' . $order;
                    }
                    if (!empty($keywords))
                    {
                        $uri .= '&amp;keywords=' . $keywords;
                    }
					if (!empty($parent_id))
                    {
                        $uri .= '&amp;parent_id=' . $parent_id;
                    }
                }
           

            break;

 

© 著作权归作者所有

共有 人打赏支持
越野小生
粉丝 3
博文 113
码字总数 32174
作品 0
杨浦
在ecshop商品列表页加一个购买数量输入框

我们在使用ecshop的时候,特别是批发站。 很多时候不能在ecshop商品列表页输入购买数量,是非常不方便的。 现在如果一次性购买好几个商品,十分的不方便,只有在ecshop的商品详细页面才能输入...

路边拾草人
2011/12/14
0
2
如何禁用ECSHOP缓存,如何关闭ECSHOP缓存

熟悉ECSHOP的老站长们都知道,ECSHOP是有缓存机制的。 ECSHOP的缓存机制从一定程度上可以减少ECSHOP反复读取数据库的几率,从而一定程度上降低服务器负担,提高访问速度。 但是启用缓存机制,...

Surjur
2015/04/30
0
0
ecshop语言包lang的加载原理

首先大家要明白的一点是:ecshop目录下的languages目录,这个就是ecshop语言包所在目录。 ecshop默认的语言包为中文简体即zh_cn目录. 语言包的载入过程都是通过ecshop的init.php中的require...

路边拾草人
2011/12/16
0
0
ecshop 实现“精品、新品、热销”板块出现选项卡效果的方法

最近做一个网络商城,直接使用ecshop的免费模板,懒得重新做,ecshop建站多日了,一直想在主页的板块中建网页选项卡鼠标经过自动切换效果,百度搜索这方面的内容也没找到合适的,今天一实验,...

小果果x
2014/12/03
0
0
重构ECShop中的Javascript(一)

ECShop一直有一个很大的问题,就是其自带的JS脚本和jQuery为主的不少使用非常多的JS框架冲突,这个冲突导致了我们在制作ECShop模板的时候,很多优秀的界面效果无法实现。可以说是ECShop最让人...

icebird
2012/11/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

postgresql 使用odbc_fdw连接 sqlserver

安装配置odbc_fdw 1.安装unixODBC apt-get install unixodbc unixodbc-dev 2.安装 Microsoft ODBC Driver 17 for SQL Server curl https://packages.microsoft.com/config/ubuntu/16.04/prod......

dubox
20分钟前
1
0
学习

z-index {堆叠顺序} vertical-align: baseline;{垂直对齐图像} vertical-align: middle;{内容在中部对齐} font-weight: bold;{使用粗体} font-style: italic;{从父元素那继承字体的样式} whi...

墨冥
25分钟前
1
0
Lock和synchronized比较详解

https://www.cnblogs.com/handsomeye/p/5999362.html

qimh
31分钟前
1
0
Postman接口测试神器从安装到精通

1 摘要 Postman 是一个接口测试和 http 请求的神器,非常好用。 官方 github 地址: https://github.com/postmanlabs Postman 的优点: 支持各种的请求类型: get、post、put、patch、delete ...

HiBlock
32分钟前
1
0
c++_拷贝构造函数

拷贝构造又叫复制构造;如果没有实现拷贝构造函数,c++会自动生成一个,叫做隐式拷贝构造函数.该自动生成的隐式拷贝构造也能应付绝大部分情况. 拷贝构造函数的格式: //定义class CTest{p...

一个小妞
33分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部