最新公告
  • 爱智习资源网欢迎您!本站大部分资源免费,收费的资源支持免登陆,微信扫码付费查看.立即加入我们
  • 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检索数据

    爱智习www.aizhixi.cn资源分享平台
    爱智习资源网 » ecshop后台通过ajax搜索原理

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    爱智习
    资源分享平台,免费源码下载!
    升级SVIP尊享更多特权立即升级