Drupal 7で1ページに10を超える検索結果を取得するにはどうすればよいですか?


17

デフォルトでは、検索ページには10件の結果のみが表示されます。結果を無制限に表示するように変更するにはどうすればよいですか?


1
なぜこれが簡単にできないのかについてのバックストーリーに興味がある人は、drupal.org
node

Drupal 8でも同じことをする必要がありましたが、検索結果のページネーションの制限を変更できません。これを手伝ってもらえますか?
Naveen Kumar

回答:


15

これにはビューを使用することをお勧めします。ビューには、検索ビューが含まれています(デフォルトでは無効になっています)。公開された検索用語フィルターを使用して検索機能を提供し、必要に応じてビューの他の側面をカスタマイズします。


推薦してくれてありがとう。最も簡単な方法のように見えますが、Drupal 7には検索ビューが含まれていません。
ミボリーゴ

コアsearch.moduleのような検索結果を表示するビューで明確に構成ビューを設定できます
ダニエル



4

Drupal 7では、カスタムモジュールでhook_query_alterを使用して、ページごとのコア検索結果アイテムを変更できました。コードでのフックの使用に慣れている場合は、次のコードスニペットを使用できます。

<?php
/**
 * Implements hook_query_alter
 */
function MY_MODULE_query_alter(&$query) {

  // This is a search result query and we want to change the
  // number of search results per page to 16.
  if ($query instanceof PagerDefault
    && ($tables = $query->getTables())
    && isset($tables['i']['table'])
    && $tables['i']['table'] === 'search_index') {
    $query->limit(16);
  }
}

0

ビューモジュールに「検索ビュー」が見つかりませんでした。ビュー7.x-3.7を使用しています。

Drupal 7の1ページで10を超える検索結果を取得するには、search_configモジュールを使用しました。最新バージョンの「7.x-1.1-beta2」を使用しました。

モジュールが有効になったら、「追加ノード検索設定」セクションの「設定」->「検索とメタデータ」->「検索設定(admin / config / search / settings)」からページャー制限を設定できます。そこに「結果」セクションが表示され、ページャー制限を指定して、1ページに10を超える検索結果を表示できます。


これはApache Solrでは機能しないようです。
ジャックライアン14

0

デフォルトの検索ビューはViewsモジュールから削除されたようですので、ここですぐにノックアップして、独自の要件の出発点として使用できるようにします。ビューのインポートダイアログを使用し、コードを貼り付けてインポートします。

$view = new view();
$view->name = 'search_test';
$view->description = '';
$view->tag = 'default';
$view->base_table = 'node';
$view->human_name = 'search test';
$view->core = 7;
$view->api_version = '3.0';
$view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */

/* Display: Master */
$handler = $view->new_display('default', 'Master', 'default');
$handler->display->display_options['title'] = 'search test';
$handler->display->display_options['use_more_always'] = FALSE;
$handler->display->display_options['access']['type'] = 'perm';
$handler->display->display_options['cache']['type'] = 'none';
$handler->display->display_options['query']['type'] = 'views_query';
$handler->display->display_options['exposed_form']['type'] = 'input_required';
$handler->display->display_options['exposed_form']['options']['text_input_required'] = 'Enter some search keywords.';
$handler->display->display_options['exposed_form']['options']['text_input_required_format'] = 'filtered_html';
$handler->display->display_options['pager']['type'] = 'full';
$handler->display->display_options['pager']['options']['items_per_page'] = '20';
$handler->display->display_options['style_plugin'] = 'default';
$handler->display->display_options['row_plugin'] = 'fields';
/* No results behavior: Global: Text area */
$handler->display->display_options['empty']['area']['id'] = 'area';
$handler->display->display_options['empty']['area']['table'] = 'views';
$handler->display->display_options['empty']['area']['field'] = 'area';
$handler->display->display_options['empty']['area']['empty'] = TRUE;
$handler->display->display_options['empty']['area']['content'] = 'No results found.';
$handler->display->display_options['empty']['area']['format'] = 'filtered_html';
/* Field: Content: Title */
$handler->display->display_options['fields']['title']['id'] = 'title';
$handler->display->display_options['fields']['title']['table'] = 'node';
$handler->display->display_options['fields']['title']['field'] = 'title';
$handler->display->display_options['fields']['title']['label'] = '';
$handler->display->display_options['fields']['title']['alter']['word_boundary'] = FALSE;
$handler->display->display_options['fields']['title']['alter']['ellipsis'] = FALSE;
/* Filter criterion: Content: Published */
$handler->display->display_options['filters']['status']['id'] = 'status';
$handler->display->display_options['filters']['status']['table'] = 'node';
$handler->display->display_options['filters']['status']['field'] = 'status';
$handler->display->display_options['filters']['status']['value'] = 1;
$handler->display->display_options['filters']['status']['group'] = 1;
$handler->display->display_options['filters']['status']['expose']['operator'] = FALSE;
/* Filter criterion: Search: Search Terms */
$handler->display->display_options['filters']['keys']['id'] = 'keys';
$handler->display->display_options['filters']['keys']['table'] = 'search_index';
$handler->display->display_options['filters']['keys']['field'] = 'keys';
$handler->display->display_options['filters']['keys']['operator'] = 'required';
$handler->display->display_options['filters']['keys']['exposed'] = TRUE;
$handler->display->display_options['filters']['keys']['expose']['operator_id'] = 'keys_op';
$handler->display->display_options['filters']['keys']['expose']['label'] = 'Search Terms';
$handler->display->display_options['filters']['keys']['expose']['operator'] = 'keys_op';
$handler->display->display_options['filters']['keys']['expose']['identifier'] = 'keys';

/* Display: Page */
$handler = $view->new_display('page', 'Page', 'page');
$handler->display->display_options['path'] = 'search';

-2

検索制限モジュールも使用するか、template.phpで次のコードを使用できます

if(arg(0) == "search" && arg(1) == "site") {

$variables['quantity'] = 5; 

}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.