小心,这里有龙。
这就是我如何做到这一点的。首先,您创建显示感兴趣内容的视图。在您感兴趣的所有字段(计数、价格、标题等)上添加排序不要担心它们不能很好地协同工作,您将在代码中动态删除/更改它们。
我创建了一个模块来包含一个处理排序的函数。创建类型为“Global:Null”的参数。它可以出现在您列表中的任何位置,但该 url 位置中必须存在一个参数,否则代码将不会执行。我通常添加标题或搜索类型。设置参数以显示所有值(如果不存在)并添加验证器。选择一个 PHP 验证器并添加以下内容。
return _mymodule_handle_sortables($view);
这将允许您快速/轻松地编辑函数的内容,而无需在每次迭代时编辑视图/保存视图/预览视图。请注意,我传递了 $_GET 变量。这不是绝对必要的,因为无论如何它都应该在函数中可用。我这样做只是为了更容易阅读。
第一步,使用开发模块获取可排序字段的名称
function _mymodule_handle_sortables(&$view) {
dpm($view->sort);
}
预览视图并记下字段的名称。获得它们后,您可以执行以下操作来更改视图的输出。
function _mymodule_handle_sortables(&$view) {
switch ($_GET['sort']) {
case 'sell_price_asc':
unset($view->sort['title']);
$view->sort['sell_price']->options['order'] = 'ASC';
break;
case 'sell_price_desc':
unset($view->sort['title']);
$view->sort['sell_price']->options['order'] = 'DESC';
break;
case 'alpha_asc':
unset($view->sort['sell_price']);
$view->sort['title']->options['order'] = 'ASC';
break;
case 'alpha_desc':
unset($view->sort['sell_price']);
$view->sort['title']->options['order'] = 'DESC';
break;
}
return true;
}
将 PHP 标头添加到您的视图中并添加以下内容
<?php echo _mymodule_sortables($_GET); ?>
现在您可以动态显示排序标题。这是一个公认的过度功能。
function _emunications_sortables($g) {
// Collect all the relevant GET parameters
$gopts = array();
foreach ($g as $k=>$v) {
if ($k == 'q') continue;
$gopts[$k] = $v;
}
$opts = http_build_query($gopts);
// Preserve the sort choice for selection
$s1 = $s2 = $s3 = $s4 = '';
switch ($gopts['sort']) {
case 'alpha_asc' : $s1 = 'selected="selected"';break;
case 'alpha_desc' : $s2 = 'selected="selected"';break;
case 'sell_price_asc' : $s3 = 'selected="selected"';break;
case 'sell_price_desc' : $s4 = 'selected="selected"';break;
}
// Unset the sort option so that it can be set in the url manually below
unset($gopts['sort']);
$opts_sort = http_build_query($gopts);
$output = "
<div class='product_index_header'>
<div class='view-selection'>
<span class='descript'>View: </span>
<a class='list' href='/products?$opts'> </a>
<span class='bar'>|</span>
<a class='grid' href='/products/grid/list?$opts'> </a>
</div>
<div class='sortable'>
<select name='droppy' class='droppy kitteh' onchange=\"window.location.href=$('select.droppy').val()\">
<option value='#'>Sort</option>
<option $s1 value='?sort=alpha_asc&$opts_sort'>a-z</option>
<option $s2 value='?sort=alpha_desc&$opts_sort'>z-a</option>
<option $s3 value='?sort=sell_price_asc&$opts_sort'>$ - $$</option>
<option $s4 value='?sort=sell_price_desc&$opts_sort'>$$ - $</option>
</select>
</div>
</div>
";
return $output;
}