文档章节

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

越野小生
 越野小生
发布于 2016/06/16 20:48
字数 496
阅读 24
收藏 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 3.0,ecshop 4.0,ecshop2.7.3全系列版本都存在着高危网站漏洞,导致网站被黑,被篡改,被挂马,许多商城系统深受其漏洞的攻击,给商城的运营者...

网站安全
09/21
0
0
ECShop 模板库项目功能详解

本文希望能给想了解ECShop库项目功能的人提供一些帮助。ec的高手就可以忽略了,有不同意见的朋友欢迎提意见。 许多刚接触 ECShop的程序员或者用户,只知道它的模板管理很强大也很方便。却不知...

阿尔卡特
2013/01/12
0
1

没有更多内容

加载失败,请刷新页面

加载更多

从源码入手,一文带你读懂Spring AOP面向切面编程

之前《零基础带你看Spring源码——IOC控制反转》详细讲了Spring容器的初始化和加载的原理,后面《你真的完全了解Java动态代理吗?看这篇就够了》介绍了下JDK的动态代理。 基于这两者的实现上...

公众号_Zack说码
15分钟前
4
0
maven 常用命令

mvn deploy -Dmaven.test.skip=true mvn source:jar deploy -Dmaven.test.skip=true mvn dependency:tree -Doutput=1.txt...

yzzzzzzzz
17分钟前
1
0
JavaScript之Promise对象

Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了 Promise 对象。 Pr...

前端攻城老湿
17分钟前
4
0
mysql事务,select for update,及数据的一致性处理

在MySQL的InnoDB中,预设的Tansaction isolation level 为REPEATABLE READ(可重读) 在select 的读取锁主要分为两种方式 select .... lock in share mode select ..... for update   这两...

细节探索者
19分钟前
2
0
python 将txt文件转换成excel

emmm,作为一个小白,不会的东西真的太多了,这两天好头大啊!加油坚持吧! #file_affilication = open('Affiliations.txt','r')import xlwtimport os import sysdef txt_xls(...

BellaYu
24分钟前
5
2

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部