A pesquisa vazia retorna a página inicial, como retornar a página de pesquisa não encontrada?


16

A função de pesquisa padrão, se o formulário de pesquisa estiver vazio, retorna a página inicial. Desejo que ele retorne uma página "desculpe, sua pesquisa não retornou resultados".

este post não responde

e esse tíquete me diz que deve funcionar dessa maneira! Alguém descobriu como alterá-lo além de usar um redirecionamento .htaccess?

Estou usando o seguinte arquivo search.php: `

        <div id="content" class="clearfix">

            <div id="main" class="col700 left clearfix" role="main">

                <h1 class="archive_title"><span>Search Results for:</span> <?php echo esc_attr(get_search_query()); ?></h1>

                <?php if (have_posts()) : while (have_posts()) : the_post(); ?>

                <article id="post-<?php the_ID(); ?>" <?php post_class('clearfix'); ?>>

                    <header>

                        <h3><a href="<?php the_permalink() ?>" rel="bookmark" title="<?php the_title_attribute(); ?>"><?php the_title(); ?></a></h3>

                        <p class="meta"><?php _e("Posted", "bonestheme"); ?> <time datetime="<?php echo the_time('Y-m-j'); ?>" pubdate><?php the_time('F jS, Y'); ?></time> <?php _e("by", "bonestheme"); ?> <?php the_author_posts_link(); ?> <span class="amp">&</span> <?php _e("filed under", "bonestheme"); ?> <?php the_category(', '); ?>.</p>

                    </header> <!-- end article header -->

                    <section class="post_content">
                        <?php the_excerpt('<span class="read-more">Read more on "'.the_title('', '', false).'" &raquo;</span>'); ?>

                    </section> <!-- end article section -->

                    <footer>


                    </footer> <!-- end article footer -->

                </article> <!-- end article -->

                <?php endwhile; ?>  

                <?php if (function_exists('page_navi')) { // if expirimental feature is active ?>

                    <?php page_navi(); // use the page navi function ?>

                <?php } else { // if it is disabled, display regular wp prev & next links ?>
                    <nav class="wp-prev-next">
                        <ul class="clearfix">
                            <li class="prev-link"><?php next_posts_link(_e('&laquo; Older Entries', "bonestheme")) ?></li>
                            <li class="next-link"><?php previous_posts_link(_e('Newer Entries &raquo;', "bonestheme")) ?></li>
                        </ul>
                    </nav>
                <?php } ?>          

                <?php else : ?>

                <!-- this area shows up if there are no results -->

                <article id="post-not-found">
                    <header>
                        <h1>No Results Found</h1>
                    </header>
                    <section class="post_content">
                        <p>Sorry, but the requested resource was not found on this site.</p>
                    </section>
                    <footer>
                    </footer>
                </article>

                <?php endif; ?>

            </div> <!-- end #main -->

            <div id="sidebar1" class="sidebar right col220">

                <?php get_search_form(); ?>



            </div>

        </div> <!-- end #content -->

`


mostrar algum código?
Kaiser #

Eu nem sei por onde começar a resolver isso (além do htaccess), então nenhum código. Qualquer ajuda é apreciada
Drai

e o seu código searchform.php e search.php?
kaiser

Eu estou usando o ossos tema que tem uma search.php mas usa o SearchForm núcleo
Drai

2
Esta é uma questão geral do WordPress, não uma questão específica de tema
Tom J Nowell

Respostas:


18

Aqui estão três maneiras de corrigir isso. Recomendamos que você use a solução 2, mas preste atenção ao jQuery na solução 1 como uma maneira de evitar a situação em primeiro lugar.

Para aqueles que desejam mais código publicado a partir do tema de perguntas, não se trata de um tema, é um problema geral do WordPress que afeta todos os sites do WordPress.

Solução 1

Você pode encontrar um tutorial detalhado sobre como corrigir isso aqui:

http://wpengineer.com/2162/fix-empty-searches/

Hoje, vejamos algo que a maioria dos profissionais nunca vê: pesquisas vazias. Você oferece um campo de entrada de pesquisa e alguém pressiona o botão enviar sem querer, sem nenhum termo inserido. O URI resultante é assim: example.com/?s=. Ele mostra o mesmo conteúdo da sua primeira página. De fato, é a primeira página.

Ninguém precisa disso.

Solução 2 (recomendado)

Publicada por Spitzerg http://wordpress.org/support/topic/blank-search-sends-you-to-the-homepage

Outra opção é adicionar um filtro de solicitação:

add_filter( 'request', 'my_request_filter' );
function my_request_filter( $query_vars ) {
    if( isset( $_GET['s'] ) && empty( $_GET['s'] ) ) {
        $query_vars['s'] = " ";
    }
    return $query_vars;
}

Então, se você estiver reutilizando a consulta de pesquisa em seu formulário de pesquisa, não esqueça de apará-la para não ter um ou mais espaços (apenas para manter as coisas limpas, provavelmente não afetará os resultados.

<input type="text" name="s" id="s" value="<?php echo trim( get_search_query() ); ?>"/>

Espero que isso ajude, parece estar funcionando até agora no meu site e não envolve a alteração de nenhum código WP, facilitando as atualizações.

Solução 3

http://www.warpconduit.net/2011/08/02/fix-redirection-and-error-page-on-empty-wordpress-search/

Semelhante à solução 2, mas não tão extensa e ligeiramente diferente.

if(!is_admin()){
    add_action('init', 'search_query_fix');
    function search_query_fix(){
        if(isset($_GET['s']) && $_GET['s']==''){
            $_GET['s']=' ';
        }
    }
}

1
O problema com a solução 2 é que ele retornará todas as postagens (ou pelo menos todas as postagens com um espaço) quando realmente não deve retornar nenhuma postagem.
Felix Eve

2

Crie um Page Search.php e cole esse código e altere seu loop com "get_template_part ('loop', 'search');

                    <div id="container">
                        <div id="content" role="main">

            <?php if ( have_posts() ) : ?>
                            <h1 class="page-title"><?php printf( __( 'Search Results for: %s', 'mb' ), '<span>' . get_search_query() . '</span>' ); ?></h1>
                            <?php
                            /* Run the loop for the search to output the results.
                             * If you want to overload this in a child theme then include a file
                             * called loop-search.php and that will be used instead.
                             */
                             get_template_part( 'loop', 'search' );
                            ?>
            <?php else : ?>
                            <div id="post-0" class="post no-results not-found">
                                <h2 class="entry-title"><?php _e( 'Nothing Found', 'mb' ); ?></h2>
                                <div class="entry-content">
                                    <p><?php _e( 'Sorry, but nothing matched your search criteria. Please try again with some different keywords.', 'twentyten' ); ?></p>
                                    <?php get_search_form(); ?>
                                </div><!-- .entry-content -->
                            </div><!-- #post-0 -->
            <?php endif; ?>
                        </div><!-- #content -->
                    </div><!-- #container -->

            <?php get_sidebar(); ?>
            <?php get_footer(); ?>

2

Com base na solução 2 de Tom, mas garantindo que nenhuma postagem seja retornada, adicione um filtro de solicitação como antes:

add_filter( 'request', 'my_request_filter' );
function my_request_filter( $query_vars ) {
    if( isset( $_GET['s'] ) && empty( $_GET['s'] ) ) {
        $query_vars['s'] = " ";
        global $no_search_results;
        $no_search_results = TRUE;
    }
    return $query_vars;
}

Mas desta vez, defina uma variável global para dizer que nenhum resultado da pesquisa deve ser retornado. Em seguida, usando um gancho posts_where, verifique se nenhuma postagem foi retornada:

add_filter( 'posts_where' , 'posts_where_statement' ); 
function posts_where_statement( $where ) {
    global $no_search_results;
    if($no_search_results) {
        $where .= ' AND 1=0';
    }
    return $where;
}

1

Verifique se a consulta de pesquisa está vazia ( get_search_query () ), basta substituir o primeiro IF por isso:

<?php if (have_posts() && get_search_query()) : while (have_posts()) : the_post(); ?>

Eu acho que essa é uma solução justa o suficiente. Simples e limpo. Sem filtros especiais e ação que pode complicar código
Kamil

0

Trato disso nos meus temas da seguinte maneira. Tente usar este código:

<?php if (!have_posts()): ?>
    <article id="post-0">
        <header>
            <h3>No posts found.</h3>
        </header> <!-- end article header -->

        <section class="post_content">
           Sorry, we found 0 posts for your search, Please try searching again.
        </section> <!-- end article section -->

        <footer>
        </footer> <!-- end article footer -->

    </article> <!-- end article -->
<?php endif; ?>

Estamos lidando com a condição if (! Have_posts ()). Coloque-o logo após o título h3.archive, antes de se iniciar (have_posts). Você pode até chamar a função de formulário de pesquisa na área de conteúdo.


0

Eu também enfrentei o mesmo problema, é o padrão dado pelo wordpress.

mas felizmente encontrei algo que me ajudou.

Adicione abaixo em "Functions.php"

 function SearchFilter($query) {
    // If 's' request variable is set but empty
    if (isset($_GET['s']) && empty($_GET['s']) && $query->is_main_query()){
        $query->is_search = true;
        $query->is_home = false;
    }
    return $query;}
add_filter('pre_get_posts','SearchFilter');

e depois substitua a linha abaixo (linha 15) em search.php

<?php if ( have_posts() && strlen( trim(get_search_query()) ) != 0 ) : ?>

Pode ser que também o ajude

Para mais detalhes, leia o seguinte: Personalize o wordpress de pesquisa vazia


0

Uma maneira de evitar a pesquisa vazia é executar a verificação javascript do valor vazio do campo de pesquisa e, se o campo encontrado estiver vazio, pare de enviar o formulário de pesquisa como abaixo:

$('#searchform').submit(function(){

            search_value =$.trim($('#searchform #s').val());

            if(search_value == ""){

                return false; // You can also pop a notification here to inform to user.
            }

});

0
# Catch empty searches
RewriteCond %{QUERY_STRING} ^s=$
RewriteRule ^ /? [L,R=301]

Não está claro como isso responde à pergunta. Você pode editar sua resposta (usando o botão editar acima) e adicionar alguns detalhes sobre o que esse código faz, onde colocá-lo e como resolve o problema, por favor?
Howdy_McGee
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.