質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

0回答

384閲覧

サイドバーの検索結果をsearch.phpへ表示させたい

m718

総合スコア2

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2022/07/06 02:32

編集2022/07/07 05:30

https://www.cg-method.com/side-job/wordpress-custom-search/
https://webfun-style.com/wordpress-custom-search/

上記サイトを参考にカテゴリなどから絞り込み検索の作成をしています。
こちらの方法ですと、作成したものの直下に検索結果が表示されます。
ここまでは表示や検索などは動作しています。
こちらの検索フォームをサイドバーに設置したいため、「search.php」にて、メイン画面に結果の表示をさせたいです。
単純に結果の部分を「search.php」に貼るだけではなく、クリックイベントで呼び出す必要性があると思うのですが、その方法がわかりません。

HTMLとCSSしか知識がないため理解が乏しくて申し訳ございません。
よろしくお願いいたします。

【custom-search.phpに記載している内容(一部ブランクあり)】

PHP

1<?php 2$args = array( 3 4 'post_type' => '〇〇〇', 5 'post_status' => 'publish', 6 'posts_per_page' => -1, 7 'orderby' => 'date', 8 'order' => 'DESC' 9); 10if (!empty($_POST['search_craft'])) { 11 foreach ($_POST['search_craft'] as $value) { 12 $search_craft[] = htmlspecialchars($value, ENT_QUOTES); 13 } 14 $tax_query_args[] = 15 array( 16 'taxonomy' => 'craft', 17 'terms' => $search_craft, 18 'field' => 'term_id', 19 'operator' => 'IN' 20 ); 21} 22if (!empty($_POST['〇〇〇'])) { 23 foreach ($_POST['〇〇〇'] as $value) { 24 $〇〇〇[] = htmlspecialchars($value, ENT_QUOTES); 25 } 26 $tax_query_args[] = 27 array( 28 'taxonomy' => '〇〇〇', 29 'terms' => $〇〇〇, 30 'field' => 'term_id', 31 'operator' => 'IN' 32 ); 33} 34 35if(!empty($_POST['search_craft']) || !empty($_POST['〇〇〇'])) { 36 $args += array('tax_query' => array($tax_query_args)); 37} 38?> 39 40<div id="search-result"> 41 <div class="search"> 42    <form method="get" action="<?php echo esc_url(home_url() . $_SERVER['REQUEST_URI']); ?>"> 43 <div class="checkbox"> 44 45        <div class="condition-title">カテゴリ別</div> 46 <div class="condition"> 47 <?php 48 $〇〇〇 = get_terms('〇〇〇', array('hide_empty' => false)); 49 foreach ($〇〇〇s as $〇〇〇) : 50 $checked = ""; 51 if (in_array($〇〇〇->term_id, (array)$search_〇〇〇)) $checked = " checked"; 52 ?> 53 <label> 54 <input type="checkbox" name="search_f〇〇〇[]" class="check_box" id="check_<?php echo esc_attr($〇〇〇->term_id); ?>" value="<?php echo esc_attr($〇〇〇->term_id); ?>" <?php echo $checked; ?>> 55 <span><?php echo esc_html($〇〇〇->name); ?></span> 56 </label> 57 <?php endforeach; ?> 58 </div> 59<input type="submit" value="検索" class="submit-button" name="s" > 60<input type="hidden" name="search" value="1"> 61 <input type="hidden" name="s" value="<?php the_search_query(); ?>"> 62 </div> 63 <?php wp_nonce_field('my-ajax-nonce', 'nonce'); ?> 64 </form> 65 66 67   68<?php if(!empty($_POST['search'])) : ?> 69 <?php 70 $the_query = new WP_Query($args); 71 if ($the_query->have_posts()) : 72 ?> 73 <div id="article-results" class="article-result h-card"> 74 <div class="item_set"> 75 <?php 76 while ($the_query->have_posts()) : 77 $the_query->the_post(); 78 ?> 79 <div class="article"> 80 <a href="<?php the_permalink(); ?>"> 81 <?php the_post_thumbnail('medium'); ?> 82 <div><?php the_title(); ?></div> 83 </a> 84 </div> 85 <?php endwhile; wp_reset_postdata(); ?> 86</div> 87<?php else : ?> 88<p>該当する記事はありませんでした。</p> 89<?php endif; ?> 90<?php endif; ?> 91</div> 92 </div> 93 94 <script> 95 var ajaxurl = '<?php echo esc_url(admin_url('admin-ajax.php')); ?>'; 96 </script> 97 <script src="<?php echo esc_url(get_stylesheet_directory_uri() . '/asset/js/search.js'); ?>"></script> 98</div>

【search.jsに記載している内容】

js

1 jQuery(function($){ 2 function customSearch(){ 3 // 1. フォームのデータを生成 4 var form = $('#search-result form').get()[0]; 5 var formData = new FormData(form); 6 formData.append('action', 'custom_search'); 7 8 // 2. Ajaxを行う 9 $.ajax({ 10 type: 'POST', 11 url: ajaxurl, 12 data: formData, 13 processData: false, 14 contentType: false, 15 success: function(data){ 16 $('#search-result').prop('outerHTML', data); 17 $('.submit-button').attr('type', 'button'); 18 } 19 }); 20 return false; 21 }; 22 23 // 3. クリックイベントの設定 24 $('.submit-button').attr('type', 'button'); 25 $(document).on('click', '.submit-button', function(){ 26 customSearch(); 27 }); 28}); 29

【functions.phpに記載している内容】

PHP

1// Ajaxで検索結果を表示する関数 2function custom_search() { 3 $nonce = $_REQUEST['nonce']; 4 if(wp_verify_nonce($nonce, 'my-ajax-nonce')) { 5 get_template_part('custom-search'); 6 } 7 die(); 8} 9add_action('wp_ajax_custom_search', 'custom_search'); 10add_action('wp_ajax_nopriv_custom_search', 'custom_search'); 11 12 13// JS 14add_action( 'wp_head', function () { ?> 15 16<script> 17jQuery(function($){ 18 19 const defaultPostsCount = 4; 20 const addPostsCount = 4; 21 let offset = 4; 22 let isAllPosts = false; 23 let flag = false; 24 25 let documentHeight = jQuery(document).height(); 26 let windowsHeight = jQuery(window).height(); 27 28 function customSearch(){ 29 var form = $('#search-result form').get()[0]; 30 var formData = new FormData(form); 31 32 offset = 0; 33 documentHeight = jQuery(document).height(); 34 windowsHeight = jQuery(window).height(); 35 isAllPosts = false; 36 flag = false; 37 38 formData.append('action', 'custom_search'); 39 formData.append('offset', 0); 40 formData.append('posts_per_page', defaultPostsCount); 41 42 flag = true; 43 $.ajax({ 44          type: 'post', 45 url: ajaxurl, 46 data: formData, 47 processData: false, 48 contentType: false, 49 success: function(data){ 50 $('#search-result').prop('outerHTML', data); 51 $('.submit-button').attr('type', 'button'); 52 53 documentHeight = jQuery(document).height(); 54 offset += addPostsCount; 55 flag = false; 56 } 57 }); 58 return false; 59 }; 60 61 $('.submit-button').attr('type', 'button'); 62 $(document).on('click', '.submit-button', function(){ 63 customSearch(); 64 }); 65}); 66 67 function addSearch() { 68 let form = $('#search-result form').get()[0]; 69 let formData = new FormData(form); 70 formData.append('action', 'add_search'); 71 formData.append('offset', offset); 72 formData.append('posts_per_page', defaultPostsCount); 73 74 if ( ! isAllPosts ) { 75 if ( ! flag ) { 76 flag = true; 77 $.ajax({ 78 type: 'post', 79 url: ajaxurl, 80 data: formData, 81 processData: false, 82 contentType: false, 83 success: function(data) { 84 let nodes = jQuery.parseHTML(data); 85 let itemCount = nodes[1].children.length; 86 if ( itemCount < addPostsCount ) { 87 isAllPosts = true; 88 } 89 90 $('#article-results').append(data); 91 documentHeight = jQuery(document).height(); 92 offset += addPostsCount; 93 flag = false; 94 } 95 }); 96 } 97 } 98 return false; 99 } 100 101 jQuery(window).on("scroll", function() { 102 let scrollPosition = windowsHeight + jQuery(window).scrollTop() + 80; 103 if (scrollPosition >= documentHeight) { 104 addSearch(); 105 } 106 }); 107 108 $("#check_1").prop("checked", true); 109 customSearch(); 110}); 111 112</script> 113<?php } ); 114add_filter('template_include','custom_search_template'); 115function custom_search_template($template){ 116 if ( is_search() ){ 117 $post_types = get_query_var('post_type'); 118 foreach ( (array) $post_types as $post_type ) 119 $templates[] = "search-{$post_type}.php"; 120 $templates[] = 'search.php'; 121 $template = get_query_template('search',$templates); 122 } 123 return $template; 124} 125

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問