ecshop后台通过ajax搜索原理

2021-09-07 0 669

Ecshop 搜索是非常强大的,但 Ecshop 前台搜索功能,背景是不同的,前台主要是通过 get 方法,提交页面的 url,并在 Ecshop 背景,是接受搜索条件的形式,然后发布的 js ajax。然后通过 ecshop ajax 返回结果。然后从结束的显示搜索结果。
让我们为例,具体分析 ecshop 背景下搜索通过 ajax。
比如我们搜索通过后台 ecshop ajax 方法返回订单

  •   1:必须在 htm 中增增加以下搜索框,订单号 <input type=”text” name=”order_sn” size=”15″ />
  •    2:html 中的 ajax 可以写成以下格式
  •        listTable.filter[‘order_sn’] = Utils.trim(document.forms[‘searchForm’].elements[‘order_sn’].value);
  •        listTable.filter[‘page’] = 1;
  •         listTable.loadList();
  •      我们可以看到以下,就是通过 listTable.loadList();来触发 ajax 的。
  •    3:我们再看 php 调用。
  •   $result = get_filter();
  •     if ($result === false)
  •     {
  •       如果返回结果为空,那么就进行 ajax 结果筛选
  •      $filter[‘invoice_no’]   = empty($_REQUEST[‘invoice_no’]) ? ” : trim($_REQUEST[‘invoice_no’]);
  •         if ($_REQUEST[‘is_ajax’] == 1)
  •         {
  •             $filter[‘order_sn’] = json_str_iconv($filter[‘order_sn’]);
  •         }
  •         $filter[‘sort_by’]    = empty($_REQUEST[‘sort_by’]) ? ‘cid’ : trim($_REQUEST[‘sort_by’]);
  •         $filter[‘sort_order’] = empty($_REQUEST[‘sort_order’]) ? ‘DESC’ : trim($_REQUEST[‘sort_order’]);
  •          $sql = “SELECT COUNT(*) FROM ” . $GLOBALS[‘ecs’]->table(‘change’) .
  •                ” WHERE 1 ” . $where;
  •         $filter[‘record_count’] = $GLOBALS[‘db’]->getOne($sql);
  •         $filter = page_and_size($filter);
  •         /* 获活动数据 */
  •         $sql = “SELECT * “.
  •                ” FROM ” . $GLOBALS[‘ecs’]->table(‘change’) .
  •                ” WHERE 1 ” . $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’];
  • }
  •     4:最后将查询结果返回
  •    $arr = array(‘res’ => $row, ‘filter’ => $filter, ‘page_count’ => $filter[‘page_count’], ‘record_count’ => $filter[‘record_count’]);
  •     return $arr;
  •    我们在来分析下,res 是返回的所有数据,filter 是过滤检索条件,page_count 是分页数量,record_count 表示查询的记录总数.
  •    通过以上封装,我们可以顺利的在 ecshop 后台使用 ajax 检索数据

本文章已结束,如转载请注明:汇站网 » ecshop 后台通过 ajax 搜索原理

收藏 (0)

微信支付 微信扫一扫

支付宝支付 支付宝扫一扫

打赏二维码
点赞 (0)

站长资源下载中心-找源码上汇站

常见问题
  • 如果付款后没有弹出下载页面,多刷新几下,有问题联系客服!
查看详情
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。
查看详情

相关文章

联系官方客服

为您解决烦忧 - 24小时在线 专业服务

  •  购买了 「意象」桌面扫码点餐小程序源码,于方寸之间开启餐饮消费新体验