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.loadList(); 我们可以看到以下,就是通过listTable.loadList();来触发ajax的。 3:我们再看php调用。 $result = get_filter(); if ($result === false) 如果返回结果为空,那么就进行ajax结果筛选 $filter['invoice_no'] = empty($_REQUEST['invoice_no']) ? '' : trim($_REQUEST['invoice_no']); $sql = "SELECT COUNT(*) FROM " . $GLOBALS['ecs']->table('change') . $filter = page_and_size($filter); /* 获活动数据 */ $filter['keywords'] = stripslashes($filter['keywords']);
}else{ $sql = $result['sql']; } 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检索数据 (责任编辑:好模板) |