ecshop 后台分页功能

Ecshop分页规则,分以下几个步骤

1.点击类别,获取第一页获取默认分类列表数据

2.点击“下一页”,采用ajax调取分页内容

 

实例分析(比如订单列表分页admin/order.php)

1.先写一个function order_list() 模块,里面要包括可以进行排序,分页,查询等功能

2.在order.php里面写一个elseif ($_REQUEST['act'] == 'list') ,这里是显示默认分页数据

3.在order.php写一个query(listtable.js默认的是先读取$_REQUEST['act'] == 'query')排序、分页、查询都在query里面完成

4.html页面(默认order_list.html完整代码)

 

实战 ”微仓功能“

1.我先写一个function depot_log_list,可以进行排序、分类、查询。这个function里面很有讲究的

重点代码

function depot_list()
{
   //*f.获取上一次保存的查询条件(如果上一次有进行查询过,则直接从f开始)
$result
= get_filter();
if ($result === false) {
    // a.查询条件
    $filter['goods_id'] = empty($_REQUEST['goods_id']) ? '' : trim($_REQUEST['goods_id']);
//b.记录总条数 $filter['record_count'] = $GLOBALS['db']->getOne("SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('depot_log') . $ex_where); //c.分页大小    
    $filter = page_and_size($filter);
    //d.查询的sql
$sql = "SELECT * FROM " . $GLOBALS['ecs']->table('depot_log') . $ex_where . " order by createtime desc LIMIT " . $filter['start'] . ',' . $filter['page_size'];     //e.保存查询条件(cookie保存) set_filter($filter, $sql); } else {
   //*f.获取上一次保存的查询条件(如果没有进行查询过,则从a查询。)

    $sql = $result['sql'];
    $filter = $result['filter'];

    }

    $depot_list = $GLOBALS['db']->getAll($sql);

  //g.组合成系统默认查询条件 $arr = array('depot_list' => $depot_list, 'filter' => $filter, 'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']); return $arr; }

e.f这两步骤非常的重要,还有if($result===false){}也非常重要

实例代码

function depot_list()
{
    $result = get_filter();
    
    if ($result === false)
    {
        $filter['user_id'] = empty($_REQUEST['user_id']) ? '' : trim($_REQUEST['user_id']);
        $filter['goods_stock'] = empty($_REQUEST['goods_stock']) ? '' : intval($_REQUEST['goods_stock']);
        
        $filter['sort_by']    = empty($_REQUEST['sort_by'])    ? 'goods_stock' : trim($_REQUEST['sort_by']);  // js的listTable.sort排序功能,也可以user_id
        $filter['sort_order'] = empty($_REQUEST['sort_order']) ? 'DESC'     : trim($_REQUEST['sort_order']);
        
        $ex_where = ' WHERE 1 ';
        $ex_where .=" AND user_id = '$filter[user_id]' ";
        
        
        $filter['record_count'] = $GLOBALS['db']->getOne("SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('depot') . $ex_where);

        /* 分页大小 */
        $filter = page_and_size($filter);
        $sql = "SELECT * FROM " . $GLOBALS['ecs']->table('depot') . $ex_where .
                 " ORDER by " . $filter['sort_by'] . ' ' . $filter['sort_order'] .
                " LIMIT " . $filter['start'] . ',' . $filter['page_size'];

       // $filter['keywords'] = stripslashes($filter['keywords']);
        set_filter($filter, $sql);
    }
    else
    {
        $sql    = $result['sql'];
        $filter = $result['filter'];
    }

    $depot_list = $GLOBALS['db']->getAll($sql);
    foreach($depot_list as $k=>$v){
        $sql = "SELECT goods_name,goods_thumb from ".$GLOBALS['ecs']->table('goods')." where goods_id = ".$v['goods_id'];
        $re = $GLOBALS['db']->getRow($sql);
        $depot_list[$k]['name'] = $re['goods_name'];
        $depot_list[$k]['goods_thumb'] = $re['goods_thumb'];    
        
    }

    $arr = array('depot_list' => $depot_list, 'filter' => $filter,
        'page_count' => $filter['page_count'], 'record_count' => $filter['record_count']);

    return $arr;
}

 

2.写一个列表

实例代码

elseif($_REQUEST['act'] == 'depot_log'){
    $smarty->assign('ur_here',      '个人微仓操作记录');
   

    $depot = depot_log_list();
    
    //print_r($depot);
    $smarty->assign('depot_log',    $depot['depot_list']);
    $smarty->assign('filter',       $depot['filter']);
    $smarty->assign('record_count', $depot['record_count']);
    $smarty->assign('page_count',   $depot['page_count']);
    $smarty->assign('full_page',    1);

    assign_query_info();
    $smarty->display('depot_log_list.htm');    
}

3.写一个列表查询(这里的depot_log_query ,还可以承接html页面的<a href="javascript:listTable.sort('goods_stock', 'DESC'); ">)

/*会员微仓 ajax 翻页调用*/
elseif ($_REQUEST['act'] == 'depot_list_query'){
    
    $depot = depot_list();
    //$depot = user_list();

    $smarty->assign('depot',    $depot['depot_list']);
    $smarty->assign('filter',       $depot['filter']);
    $smarty->assign('record_count', $depot['record_count']);
    $smarty->assign('page_count',   $depot['page_count']);
    
    $sort_flag  = sort_flag($depot['filter']);
    $smarty->assign($sort_flag['tag'], $sort_flag['img']);

    make_json_result($smarty->fetch('depot_list.htm'), '', array('filter' => $depot['filter'], 'page_count' => $depot['page_count']));  // 注意此处的结构,缺少mke_json_result不行     
}

 4.html页面html代码

 

<table cellpadding="3" cellspacing="1">
  <tr>
    <th width="80">
      <input οnclick='listTable.selectAll(this, "checkboxes")' type="checkbox">
      {$lang.record_id}{$sort_user_id}
    </th>
    <th width="60">缩略图</th>
    <th>商品名称</th>
    <th><a href="javascript:listTable.sort('order_amount', 'DESC'); ">库存</a></th>
    <th>{$lang.handler}</th>
  <tr>
  {foreach from=$depot item=vo}
  <tr>
    <td><input type="checkbox" name="checkboxes[]" value="{$vo.id}" notice="{if $user.user_money ne 0}1{else}0{/if}"/>{$vo.id}</td>
    <td class="first-cell"><a href="../goods.php?id={$vo.id}" target="_blank"><img src="../{$vo.goods_thumb}" width=40 style="border: 1px solid #eee"/></a></td>
    <td><span οnclick="listTable.edit(this, 'edit_email', {$user.user_id})"><a href="../goods.php?id={$vo.id}" target="_blank">{$vo.goods_name}</a></span></td>
    <td align="center">{$vo.goods_stock}</td>
    <td align="center">
     
      <a href="users.php?act=depot_log&user_id={$vo.user_id}&goods_id={$vo.goods_id}" title="查看记录"><img src="images/icon_view.gif" border="0" height="21" width="21" /></a>
      
    </td>
  </tr>
  {foreachelse}
  <tr><td class="no-records" colspan="11">{$lang.no_records}</td></tr>
  {/foreach}
  <tr>
      <td colspan="2">
      <input type="hidden" name="act" value="batch_remove" />
      <input type="submit" id="btnSubmit" value="{$lang.button_remove}" disabled="true" class="button" /></td>
      <td align="right" nowrap="true" colspan="9">
      {include file="page.htm"}
      </td>
  </tr>
</table>

 

js代码

{if $full_page}
</div>
<!-- end users list -->
</form>
<script type="text/javascript" language="JavaScript">
<!--
listTable.recordCount = {$record_count};
listTable.pageCount = {$page_count};

{foreach from=$filter item=item key=key}
listTable.filter.{$key} = '{$item}';
{/foreach}

{literal}
onload = function()
{
    //document.forms['searchForm'].elements['keyword'].focus();
    // 开始检查订单
    startCheckOrder();
  //a.listtable.js默认是listTable.query="query",也就是order.php页面的elseif ($_REQUEST['act'] == 'query')
如果不想只想默认的$_REQUEST['act']=='query',就需要写上以下代码
listTable.query
= "depot_list_query"; 默认载入使用(第一次点击列表) } /** * 搜索用户 */ function searchUser() { //listTable.filter['keywords'] = Utils.trim(document.forms['searchForm'].elements['keyword'].value); listTable.filter['page'] = 1;
// b.与a作用一样 listTable.query
= "depot_list_query"; 承接上一次查询条件 listTable.loadList(); } //--> </script> {/literal} {include file="pagefooter.htm"} {/if}

如果改变了,默认的query查询;则a,b两处都不可以少

 

分页实例化结构代码

Array
(
    [depot_list] => Array
        (
            [0] => Array
                (
                    [id] => 1
                    [user_id] => 1
                    [goods_id] => 2
                    [goods_stock] => 2
                    [goods_name] => 荷兰Nutrilon牛栏奶粉 
                )

            [1] => Array
                (
                    [id] => 7
                    [user_id] => 1
                    [goods_id] => 6
                    [goods_stock] => 4
                    [goods_name] => 1111
                )

        )

    [filter] => Array
        (
            [user_id] => 1
            [record_count] => 2
            [page_size] => 4
            [page] => 1
            [page_count] => 1
            [start] => 0
        )

    [page_count] => 1
    [record_count] => 2
)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前言 3 一、商圈和地区进行关联 4 二、其他页面显示购买记录的函数 5 三、多货币解决方案 6 四、仿淘宝商品详细页实现尺码颜色关联显示库存 12 五、仿淘宝商品详细页加入购物车效果 14 六、ecshop加入购物车效果(各个页面) 22 七、商品列表页面“喜欢“ 功能实现 29 八、商品列表也显示获赠消费积分 32 九、分析 ecshop 里的$GLOBALS 37 十、解决 选择属性 直接就是属性价格不需要在原价基础上加价 38 十一、商品详细页下载商品介绍相关图片 39 十二、实现后台二次开发后功能模块仍然可以分配权限 41 十三、ecshop调用bbs数据 42 十四、整理了一个 获取用户等级的函数 43 十五、商品页显示具体属性排序 44 十六、解决ecshop新建页面分页问题 49 十七、刚修改的伪静态分类URL 52 十八、ecshop批发销售 66 十九、网银支付直通插件 实现方法 69 二十、商品列表页多图切换的实现 75 二十一、完善论坛发布的qq登录插件 77 二十二、倒计时代码 78 二十三、关于ecshop回调函数应用 83 二十四、商品内容页加订单留言功能分析 84 二十五、有关商品详细页是常规显示还是显示宣传页的实现方法 85 二十六、后台添加搜索功能讲解 87 二十七、分享ec搜索出现相关商品的效果滑动效果(模仿百度) 88 二十八、修改注册发送邮件(更新) 94 二十九、新增加一调用编辑器函数 97 三十、简单实现 各个页面都可显示友情链接 97 三十一、Ecshop系统框架分析 99 三十二、二次开发技术共享 后台邮件群发共享 100 三十三、ecshop内页调用友情链接 100 三十四、项目要求在后台商品分类添加图片的功能。 102 三十五、分类按照拼音第一字母排序显示实现 102 三十六、获取分类的一级分类和二级分类 106 三十七、如何调用解决列表的购买数量 107 三十八、详情页调评论次数 108 三十九、关于购买数量 订单数量 109 四十、Ecshop ajax应用讨论 109 四十一、调用当前分类或当前分类的下级分类函数 115 四十二、在商品列表显示购买记录 118 四十三、ajax更新购物车数量 118 四十四、PHP导出excle数据 123 四十五、页面多倒计时显示最新修改 125 四十六、关于lbi文件控制原理分析 129 四十七、页面浏览历史图片调用分析 130

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值