こちらのサイトを参考にワードプレスの固定ページに自作の絞り込み検索機能を作りました。
検索結果を一覧で表示し、ページネーションさせたいのですが2ページ目を表示できません。
●できていること
検索結果を一覧で表示→1ページに2つの記事を表示→下に”1.2.3>>最後へ”の様なページに飛ぶリンクを表示
と、ここまではできています。
●できないこと
リンクの「2」や「3」や「最後へ」や「>>」などを押してもリンク先のページに移動しません。
また、URLが本来ならば"xxx.com/research/page/2/"などのようになるはずですが、
"xxx.com/wp-admin/admin-ajax.php/page/2/"となっています。
(※researchは一覧を表示する固定ページのスラッグです。)
表示されている画面は真っ白で数字の0のみ表示されています。
その画面のソースを見ると0のみが出力されているようです。
WP-PageNaviというプラグインを使っても同じ結果になります。
●知りたいこと
原因はこのURLがおかしいことにあると思い、いろいろと探っているのですが、
私がPHPやWEB系が初心者のため、どこでどのようにリンクのURLを設定していてるのか理解できていません。
どの様な仕組みで2ページ目以降のリンクを設定しているのか仕組みや、URLがおかしくなる原因を知りたいです。
どなたかご教授の程よろしくお願いいたします。
以下コードです。
custumserch.php
<!-- 1. 検索条件の取得と変数の設定 --> <?php // ページ番号を取得 $paged = get_query_var('paged') ? get_query_var('paged') : 1; $args = array( 'paged' => $paged, // ページ番号を設定 'post_type' => 'post', 'post_status' => 'publish', 'posts_per_page' => 2, 'orderby' => 'date', 'order' => 'DESC' ); if (!empty($_POST['search_category'])) { foreach ($_POST['search_category'] as $value) { $search_category[] = htmlspecialchars($value, ENT_QUOTES); } $args += array('category__in' => $search_category); } if (!empty($_POST['search_tag'])) { foreach ($_POST['search_tag'] as $value) { $search_tag[] = htmlspecialchars($value, ENT_QUOTES); } $args += array('tag__in' => $search_tag); } if (!empty($_POST['search_color'])) { foreach ($_POST['search_color'] as $value) { $search_color[] = htmlspecialchars($value, ENT_QUOTES); } $tax_query_args[] = array( 'taxonomy' => 'color', 'terms' => $search_color, 'field' => 'slug', 'operator' => 'IN' ); } if (!empty($_POST['search_image_texture'])) { foreach ($_POST['search_image_texture'] as $value) { $search_image_texture[] = htmlspecialchars($value, ENT_QUOTES); } $tax_query_args[] = array( 'taxonomy' => 'image_texture', 'terms' => $search_image_texture, 'field' => 'slug', 'operator' => 'IN' ); } if (!empty($_POST['search_image_texture']) || !empty($_POST['search_image_texture'])) { $args += array('tax_query' => array($tax_query_args)); } ?> <!-- (追記1)Ajaxの結果を表示する領域を設定 --> <div id="search-result"> <div class="search"> <?php if (!empty($_POST['search'])) : ?> <?php $the_query = new WP_Query($args); if ($the_query->have_posts()) : ?> <div class="result"> <?php while ($the_query->have_posts()) : $the_query->the_post(); ?> <div class="article"> <a href="<?php the_permalink(); ?>"> <?php the_post_thumbnail('medium'); ?> <div><?php the_title(); ?></div> </a> </div> <?php endwhile; wp_reset_postdata(); ?> </div> <?php // ページャーを設置 echo paginate_links(array( 'total' => $the_query->max_num_pages, 'current' => $paged, 'type' => 'list', )); ?> <?php else : ?> <p>該当する物件はありませんでした。</p> <?php endif; ?> <?php endif; ?> <form method="post" action="<?php echo esc_url(home_url() . $_SERVER['REQUEST_URI']); ?>"> <div class="checkbox"> <section class="typeA"> <!-- カテゴリーを取得 --> <input id="TAB-A01" type="radio" name="TAB-A" checked="checked"> <label class="tabLabel" for="TAB-A01">業種</label> <div class="content"> <ul class="conditions"> <?php $categories = get_categories(array('hide_empty' => false)); foreach ($categories as $category) : $checked = ""; if (in_array($category->term_id, $search_category)) $checked = " checked"; ?> <li> <label> <input type="checkbox" name="search_category[]" value="<?php echo esc_attr($category->term_id); ?>" <?php echo $checked; ?>> <?php echo esc_html($category->name); ?> </label> </li> <?php endforeach; ?> </ul> </div> <!-- タグを取得 --> <input id="TAB-A02" type="radio" name="TAB-A"> <label class="tabLabel" for="TAB-A02">形・アルファベット</label> <div class="content"> <ul class="conditions"> <?php $tags = get_tags(array('hide_empty' => false)); foreach ($tags as $tag) : $checked = ""; if (in_array($tag->term_id, $search_tag)) $checked = " checked"; ?> <li> <label> <input type="checkbox" name="search_tag[]" value="<?php echo esc_attr($tag->term_id); ?>" <?php echo $checked; ?>> <?php echo esc_html($tag->name); ?> </label> </li> <?php endforeach; ?> </ul> </div> <!-- アルファベット --> <input id="TAB-A03" type="radio" name="TAB-A"> <label class="tabLabel" for="TAB-A03">カラー</label> <div class="content"> <ul class="conditions"> <?php $colors = get_terms('color', array('hide_empty' => false)); foreach ($colors as $color) : $checked = ""; if (in_array($color->slug, $search_color)) $checked = " checked"; ?> <li> <label> <input type="checkbox" name="search_color[]" value="<?php echo esc_attr($color->slug); ?>" <?php echo $checked; ?>> <?php echo esc_html($color->name); ?> </label> </li> <?php endforeach; ?> </ul> </div> <!-- 色 --> <input id="TAB-A04" type="radio" name="TAB-A"> <label class="tabLabel" for="TAB-A04">イメージ・質感</label> <div class="content"> <ul class="conditions"> <?php $image_textures = get_terms('image_texture', array('hide_empty' => false, 'orderby' => 'slug')); foreach ($image_textures as $image_texture) : $checked = ""; if (in_array($image_texture->slug, $image_texture)) $checked = " checked"; ?> <li> <label> <input type="checkbox" name="image_texture[]" value="<?php echo esc_attr($image_texture->slug); ?>" <?php echo $checked; ?>> <?php echo esc_html($image_texture->name); ?> </label> </li> <?php endforeach; ?> </ul> </div> </section> </div> <input type="submit" value="検索" class="submit-button"> <input type="hidden" name="search" value="1"> <!-- (追記2)nonceのhiddenタグを生成 --> <?php wp_nonce_field('my-ajax-nonce', 'nonce'); ?> </form> </div> <!-- (追記3)Ajaxで使う変数の設定とスクリプトを読み込み --> <script> var ajaxurl = '<?php echo esc_url(admin_url('admin-ajax.php')); ?>'; </script> <script src="<?php echo esc_url(get_stylesheet_directory_uri() . '/js/main.js'); ?>"></script> </div>
main.js
jQuery(function($){ function customSearch(){ // 1. フォームのデータを生成 var form = $('#search-result form').get()[0]; var formData = new FormData(form); formData.append('action', 'custom_search'); // 2. Ajaxを行う $.ajax({ type: 'POST', url: ajaxurl, data: formData, processData: false, contentType: false, success: function(data){ $('#search-result').prop('outerHTML', data); $('.submit-button').attr('type', 'button'); } }); return false; }; // 3. クリックイベントの設定 $('.submit-button').attr('type', 'button'); $(document).on('click', '.submit-button', function(){ customSearch(); }); }); コード
追記いたします。
KazuhiroHatano様にご指示をいただきました変数の内容を記載いたします。
var_dump($paged);
int(1)
var_dump($_REQUEST);
array(5) { ["TAB-A"]=> string(2) "on" ["search"]=> string(1) "1" ["nonce"]=> string(10) "xxxxxxxxxx" ["_wp_http_referer"]=> string(10) "/research/" ["action"]=> string(13) "custom_search" }
var_dump($_SERVER['REQUEST_URI']);
string(24) "/wp-admin/admin-ajax.php"
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/01/05 03:00
2022/01/05 05:06 編集
2022/01/06 02:20
2022/01/06 04:04
2022/01/06 04:13
2022/01/06 23:41
2022/01/07 01:43
2022/01/07 03:36
2022/01/07 03:45
2022/01/07 04:34
2022/01/07 04:52
2022/01/07 10:00
2022/01/11 05:29