Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
Copa WPB
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

Como definir uma imagem de reserva padrão para miniaturas de posts do WordPress

As imagens em destaque são essenciais para tornar suas postagens no WordPress visualmente atraentes e envolventes. Elas chamam a atenção dos leitores e ajudam seu conteúdo a se destacar.

No entanto, sabemos que criar imagens exclusivas para cada publicação pode ser um desafio, especialmente se você estiver administrando um site movimentado como o nosso.

É aí que a configuração de uma imagem de fallback padrão para miniaturas de posts do WordPress se torna útil. Isso garante que suas postagens sempre tenham uma imagem, mantendo uma aparência profissional em todo o site, mesmo quando você não tem tempo para criar uma imagem em destaque personalizada.

Neste artigo, mostraremos como configurar uma imagem de fallback padrão para as miniaturas de postagens do WordPress.

How to Set a Default Fallback Image for WordPress Post Thumbnails

Por que definir uma imagem em destaque padrão no WordPress?

No WordPress, as imagens em destaque (ou miniaturas de postagens) são elementos visuais muito importantes que representam seu conteúdo.

Elas chamam a atenção no seu blog, nos arquivos e nas mídias sociais, dando aos leitores uma prévia rápida do que esperar.

Example of featured images in WPBeginner

Mas o que acontece quando você não tem uma imagem exclusiva para cada post? É aí que a configuração de uma imagem em destaque padrão do WordPress é útil.

Essa solução é perfeita para sites de notícias movimentados, conteúdo mais antigo sem imagens ou para manter uma aparência de marca consistente em seu site WordPress.

Sem uma imagem padrão, seu site pode parecer estranho.

Publicações sem imagens podem se destacar de forma negativa, fazendo com que seu site pareça confuso. Isso pode confundir os leitores e fazer com que seu site pareça menos profissional.

Example of a missing featured image

Com isso em mente, vamos dar uma olhada em três maneiras fáceis de configurar uma imagem em destaque padrão para as publicações do seu blog no WordPress. Você pode usar os links rápidos abaixo para pular para o método de sua preferência:

Esse método é perfeito para iniciantes, pois não requer nenhuma codificação. Usaremos o plug-in Default Featured Image para mostrar uma miniatura de postagem padrão de fallback do WordPress.

Primeiro, instale e ative o plug-in Default Featured Image em seu site do WordPress. Se não tiver certeza de como fazer isso, consulte nosso guia para iniciantes sobre a instalação de plug-ins do WordPress.

Depois de ativado, vá para Configurações “ Mídia no painel do WordPress. Você verá uma nova opção para “Selecionar imagem em destaque padrão”. Clique nesse botão para abrir sua biblioteca de mídia.

Aqui, você pode escolher uma imagem existente ou carregar uma nova imagem para usar como fallback para postagens.

Uploading a featured image to the Default Featured Image plugin

Depois de selecionar a imagem, você verá opções para definir as dimensões máximas para os tamanhos padrão da imagem em destaque.

Você pode ajustá-las se quiser ou deixá-las como estão se estiver satisfeito com as configurações padrão.

Setting the dimensions for the default featured image

Quando terminar, role a tela para baixo e clique em “Save Changes” (Salvar alterações). Para ver suas alterações em ação, visualize seu site no celular e no desktop.

Agora, sempre que você criar uma postagem sem definir uma imagem em destaque, o site do WordPress usará automaticamente essa imagem de fallback como miniatura da postagem.

Example of setting a default featured image using a plugin

Se você se sentir confortável com a codificação ou preferir não usar o outro plug-in, poderá definir manualmente uma imagem em miniatura de postagem de reserva.

Usaremos o plug-in WPCode para adicionar essa funcionalidade com segurança e facilidade.

Primeiro, instale e ative o plug-in WPCode em seu site do WordPress. Se precisar de ajuda, consulte nosso guia sobre a instalação de plug-ins do WordPress.

Depois de ativado, vá para Code Snippets “ + Add Snippet em seu painel do WordPress. Escolha “Add Your Custom Code (New Snippet)” (Adicionar seu código personalizado (novo snippet)) e clique em “+ Add Custom Snippet” (Adicionar snippet personalizado).

Adding a new custom code snippet in WPCode

Agora, dê ao seu snippet um nome como “Set Fallback Image for Posts Without Featured Images” (Definir imagem de reserva para publicações sem imagens em destaque).

Além disso, altere o tipo de código para “PHP Snippet”.

Setting a default fallback image with WPCode

Em seguida, cole o código fornecido na caixa Code Preview (Visualização de código):

function set_default_featured_image( $html, $post_id, $post_thumbnail_id, $size, $attr ) {
    if ( empty( $post_thumbnail_id ) ) {
        // Replace 'http://example.com/path/to/your/default-image.jpg' with the URL of your default image.
        $default_image_url = 'http://example.com/path/to/your/default-image.jpg';
        $html = '<img src="' . esc_url( $default_image_url ) . '" class="wp-post-image" alt="Default Image"/>';
    }
    return $html;
}
add_filter( 'post_thumbnail_html', 'set_default_featured_image', 10, 5 );

function set_default_featured_image_url( $url, $post_id ) {
    if ( empty( get_post_thumbnail_id( $post_id ) ) ) {
        // Replace 'http://example.com/path/to/your/default-image.jpg' with the URL of your default image.
        $url = 'http://example.com/path/to/your/default-image.jpg';
    }
    return $url;
}
add_filter( 'default_post_thumbnail_url', 'set_default_featured_image_url', 10, 2 );

Esse código faz duas coisas principais. Primeiro, ele define uma imagem padrão a ser exibida quando um post não tem uma imagem em destaque.

Em segundo lugar, ele garante que essa imagem em destaque padrão seja usada de forma consistente em todo o site, inclusive em locais em que apenas o URL da imagem é necessário.

Você precisará substituir o URL da imagem de exemplo no código pelo URL da imagem padrão escolhida (consulte as partes destacadas do exemplo de código).

Se não tiver certeza de como obter o URL da sua imagem, consulte nosso artigo sobre como obter o URL das imagens que você carrega no WordPress.

Depois de colar o código, role para baixo até a seção Inserção. Mantenha o método de inserção como “Auto Insert” e altere o local para “Frontend Only”.

Por fim, alterne o botão no canto superior direito para “Active” (Ativo) e clique em “Save Snippet” (Salvar snippet).

Choosing Frontend Only as the code insertion location in WPCode

Quando você visualizar a página inicial do seu blog agora, deverá ver a imagem padrão aparecendo em todas as postagens que não tiverem uma imagem em destaque definida.

Método 3: Definir a primeira imagem como miniatura de postagem com o código

Esse método usa automaticamente a primeira imagem em sua postagem como miniatura. É uma ótima opção se você sempre inclui imagens em suas postagens e deseja economizar tempo por não definir as imagens em destaque manualmente.

Para isso, usaremos novamente o plug-in WPCode. Se você ainda não o instalou, siga nosso guia para iniciantes sobre a instalação de plug-ins do WordPress.

Depois de ativar o WPCode, acesse Code Snippets “ + Add Snippet em seu painel do WordPress. Escolha “Add Your Custom Code (New Snippet)” (Adicionar seu código personalizado (novo snippet)) e clique em “+ Add Custom Snippet” (Adicionar snippet personalizado).

Nesse estágio, você pode nomear seu snippet como “Use First Image in Post as Featured Image”.

Em seguida, altere o tipo de código para “PHP Snippet”.

Custom code for using first image as featured image, inserted using WPCode

Em seguida, cole o seguinte código na caixa Code Preview (Visualização de código):

// Function to get the first image from the post content
function get_first_image_from_content( $post_content ) {
    $dom = new DOMDocument();
    libxml_use_internal_errors(true);
    $dom->loadHTML($post_content);
    libxml_clear_errors();

    $xpath = new DOMXPath($dom);
    $image_nodes = $xpath->query("//img");

    if ( $image_nodes->length > 0 ) {
        $image_url = $image_nodes->item(0)->getAttribute('src');
        return $image_url;
    }

    return false;
}

// Function to set the first image as the featured image
function set_first_image_as_featured( $post_id ) {
    if ( wp_is_post_autosave( $post_id ) || wp_is_post_revision( $post_id ) ) {
        return;
    }

    if ( has_post_thumbnail( $post_id ) ) {
        return;
    }

    $post = get_post( $post_id );
    if ( ! $post ) {
        return;
    }

    $image_url = get_first_image_from_content( $post->post_content );

    if ( $image_url ) {
        $upload_dir = wp_upload_dir();
        if ( false !== strpos( $image_url, $upload_dir['baseurl'] ) ) {
            $attachment_id = attachment_url_to_postid( $image_url );
            if ( $attachment_id ) {
                set_post_thumbnail( $post_id, $attachment_id );
            }
        }
    }
}
add_action( 'save_post', 'set_first_image_as_featured' );

// Function to filter the post thumbnail HTML
function filter_post_thumbnail_html( $html, $post_id, $post_thumbnail_id, $size, $attr ) {
    if ( ! $html ) {
        $post = get_post( $post_id );
        if ( $post ) {
            $image_url = get_first_image_from_content( $post->post_content );
            if ( $image_url ) {
                $html = '<img src="' . esc_url( $image_url ) . '" alt="' . esc_attr( get_the_title( $post_id ) ) . '" class="frame" />';
            }
        }
    }
    return $html;
}
add_filter( 'post_thumbnail_html', 'filter_post_thumbnail_html', 10, 5 );

Simplificando, esse código procura a primeira imagem no conteúdo de sua postagem. Se ele encontrar uma imagem e não houver uma imagem em destaque definida, essa primeira imagem se tornará a imagem em destaque.

Esse código funciona automaticamente sempre que você salva ou atualiza uma postagem. Ele só define uma nova imagem em destaque se ainda não houver uma definida, portanto, não substituirá nenhuma imagem em destaque que você tenha definido manualmente.

Depois disso, role para baixo até a seção Inserção. Certifique-se de manter o Insert Method como “Auto Insert” e o Location como “Run Everywhere”.

Por fim, alterne o botão no canto superior direito para “Active” (Ativo) e clique em “Save Snippet” (Salvar snippet).

Applying the code snippet everywhere using WPCode

Quando você visualizar a página inicial do seu blog agora, deverá ver a primeira imagem de cada publicação sendo usada como miniatura.

Assim:

Using first image as featured image example

Bônus: Dicas essenciais sobre imagens do WordPress

Agora que você aprendeu a definir imagens de fallback padrão para as miniaturas de suas postagens, aqui estão algumas outras técnicas úteis relacionadas a imagens para o WordPress:

Esperamos que este artigo tenha ajudado você a aprender como definir uma imagem de fallback padrão para as miniaturas de posts do WordPress. Talvez você também queira conferir nossas escolhas de especialistas dos melhores construtores de páginas de arrastar e soltar para WordPress e nosso guia definitivo sobre como editar um site WordPress.

Se você gostou deste artigo, inscreva-se em nosso canal do YouTube para receber tutoriais em vídeo sobre o WordPress. Você também pode nos encontrar no Twitter e no Facebook.

Divulgação: Nosso conteúdo é apoiado pelo leitor. Isso significa que, se você clicar em alguns de nossos links, poderemos receber uma comissão. Veja como o WPBeginner é financiado, por que isso é importante e como você pode nos apoiar. Aqui está nosso processo editorial.

Avatar

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

O kit de ferramentas definitivo WordPress

Obtenha acesso GRATUITO ao nosso kit de ferramentas - uma coleção de produtos e recursos relacionados ao WordPress que todo profissional deve ter!

Reader Interactions

66 ComentáriosDeixe uma resposta

  1. Syed Balkhi says

    Hey WPBeginner readers,
    Did you know you can win exciting prizes by commenting on WPBeginner?
    Every month, our top blog commenters will win HUGE rewards, including premium WordPress plugin licenses and cash prizes.
    You can get more details about the contest from here.
    Start sharing your thoughts below to stand a chance to win!

  2. Muhammed says

    How do you set up dafault thumbnail for posts that have thumbnails already but the images no longer exist on your server? And these posts are up to 1,000, which were created years ago. And these broken images make your site look messy.

  3. Hum says

    Hi,

    I tried to implement above code in my site with Sahifa theme (it doesn’t have default fallback thumbnail, I guess). However I am not success yet. I just want to display default image if post has no image. Here is the code in template:

    <a href="” title=”” rel=”bookmark”>

    Where and what code should I add to above to meet my requirement?

    Many thanks in advance.

  4. Andrei Filonov says

    Unfortunately adding condition “has_post_image” may be tricky when plugins are used for “latest” or “related” posts, as we don’t want to mess up plugin code :)

    In this case we can add a custom filter to load custom default image when the_post_thumbnail is called:

    You can use it as a starting point and expand if you want custom default images for different post types or categories.

  5. JAVAD says

    hi i use auto-post-thumbnail to create auto thumbnail

    now i want if i enable show excerpt in my theme , first image or featured image shown on above the post in index.php

  6. Siddharth says

    Great! It is easy to understand now. I have seen different preference of feature images in many different themes but your blog post made sense.

  7. Laura P. says

    How can I tweak this function for adding a specific image (example.jpg) as the default image for post type: topic? Basically, I’m trying to set a default image for bbpress topic pages.

    Thanks!

    L

  8. Jose Salazar says

    Hi!

    Im adding the First Post Image as the Default Fallback, but would like to display attachment image ONLY if size in pixels is between 460×350 and 700×525. Is that possible? Any suggestions?

    Thanks in advance!

    • Dee says

      Hi Jose, How did you get the first image to show up? I removed the echo thumbnail and else statements and only have echo main image but it’s still showing the manual featured image. Thanks

  9. Paal Joachim Romdahl says

    Hey

    Could someone update the above code but this time to be added into the functions.php file?

    Perhaps even add on to how to define various category post images.

    Thank you!

  10. Nestor Cheese says

    Works great, thanks! The thing, though. is that the default thumbnail links automatically to the post but if you add a featured image, it doesn’t link. Has anyone resolved this?

  11. wfriley says

    I pasted the code into the functions.php file and checked my site to make sure nothing went haywire. For some reason my posts are now ending up on my static home page. I removed the code but it did not correct the problem. Any chance you might know a fix for that? I tried recreating the home page but the same thing happens.

  12. Alexandre Michel says

    Hi, looks like it’s working but in my single post page the default image does not show up. It returns blank code. Would you happen to know why?

  13. Mitch Larouche says

    How can I do an if statement where if there is no FEATURE or no MEDIA image then show google ad? This works but I want to add and IF for when I add a media image also. So if there is NO media image or feature image INCLUDE the adsense…php ad.

    ?php if( has_post_thumbnail() ) { ?>
    ?php } else { ?>
    ?php include(‘adsense_singlepost_top_square.php’) ?>
    ?php }

    Can’t see to figure out how to include the media file from the post?

  14. Chetan Patel says

    Hello I have Wallpapers site on wordpress. I have little problem with images. Google Indexing my thumbnail instead of full size images. I want to index only full size image. Any way to do this. ?? please help ,me.

  15. Doop says

    This is great except if you upload an image to a post and then decide to delete it, it will still be attached to the post.

  16. Byron says

    Hi,
    I’m tying to set a default image for one of my custom post types. I’ve not been able to do this and have tried many of the plugin on the WP repository… Default featured image sets a featured image to All post types even Ubermenu.

    I need to limit this to one post type. Do you have any suggestions for me please?

    • WPBeginner Support says

      Byron, does the custom post type you want to set the default thumbnail for has featured image support? If yes then using this code in your theme template should display the default post thumbnail.

      <?php if ( has_post_thumbnail() ) {
      the_post_thumbnail();
      } else { ?>
      <img src="<?php bloginfo('template_directory'); ?>/images/default-image.jpg" alt="<?php the_title(); ?>" />
      <?php } ?>
      

      Administrador

  17. Paul says

    Okay, that didn’t work…! The a href tag messed it up. How do I show you code?

    <a href="" title="" >

    Try that!

  18. Alejandro says

    Excellent solution. Now, how I can use this to assign to a specific category and taking ramdom images from a folder?

    <img src="/images/default-image.jpg” alt=”” />

    Thank you a lot!

    • WPBeginner Support says

      This requires a more complicated solution. First you would want to set an image for each category and upload them to a specific folder probably using category slug as the image file names. Then you need to get the category slug for each post and use it as the fallback image URL.

      Administrador

  19. Konstantin says

    I am having a small problem, when calling the image, it only shows the full image, not the ones I try to specify (small, medium, thumbnail, etc).

    Did anything change in wp3.7+? The images are there, and are being created, but they wont display :(

  20. Susan Clifton says

    Will this work with a custom post type? I’m building a Portfolio theme. Your tutorials are always so helpful. I don’t really know PHP but I’m comfortable with messing with it.

  21. Tania says

    Is there a way to show a default “image not available” image when the source image src is empty ?
    I’m promoting amazon products in my blog (using API) but most of the products do not have image. By providing a default “image not available” image, I can help my visitors to understand that the sellers do not provide any image.

    I prefer html, css or javascript solution.

    thanks and sorry about my english ;)

  22. Waheed Akhtar says

    Hi Balkhi,

    I have some old posts where post thumbnail is not defined. Also may be for some posts there’s no image uploaded (did it manually through FTP and linked in the post). The result is I don’t see any featured thumbnail for the post.

    Is there a way we can grab the first image, resize it (e.g. 200 x 200) and show as featured image?

    Thanks.

  23. Amin says

    Thanks for this post. I’ve been searching for days to find a way to have an automatic default featured image. This saved me so much time! Thanks a lot.

  24. James says

    I’ve tried to merge both options but failed.

    How would you Check for Thumbnail, but if none then check for First Post Image, but then if none then post Default Branded Image?

      • Editorial Staff says

        Try this:

        function get_fbimage() {
          if ((function_exists('has_post_thumbnail')) && (has_post_thumbnail())) {
          $src = wp_get_attachment_image_src( get_post_thumbnail_id($post->ID), '', '' );
          $fbimage = $src[0];
          } else {
            global $post, $posts;
            $fbimage = '';
            $output = preg_match_all('/<img.+src=[\'"]([^\'"]+)[\'"].*>/i',
            $post->post_content, $matches);
            $fbimage = $matches [1] [0];
          }
          if(empty($fbimage)) {
        	
            $fbimage = //Define Default URL HEre;
          }
          return $fbimage;
        }
        

        Administrador

        • Vanessa K says

          Hi :), great tutorial. I’m a somewhat beginner for a lot of wordpress code. I tried to follow this tutorial for setting up the fall back image a few months ago and failed :p but was able to successfully implement it just now. Yay me! haha. However I would really like to set it up in the way James mentioned…

          “How would you Check for Thumbnail, but if none then check for First Post Image, but then if none then post Default Branded Image?”

          Posting the code you offered in response to his request is only showing up with syntax errors for me in my functions file :/. I’m sure it’s me and not the code :p but any suggestions? Thanks! And Happy Thanksgiving!

  25. jfwebdesignstud says

    wp_get_attachment_image_src( get_post_thumbnail_id( $post->ID ), ‘full’ );
     
    can this be used somehow with this for including pinterest featured image

  26. CharlesUibel says

    Yes But I don’t want to just display the fallback image, I want to assign the image to permanently be the featured image.

  27. leitseitenmacher says

    how do you create a real fall back thumbnail?

    with the solution a post rhumbnail is shown but therefore not registerate in the backend.

    any solution

    • wpbeginner says

      @leitseitenmacher The whole idea of a fallback is to show when nothing is selected at the thumbnails area in the backend… so NO you will not be able to see it in the backend….

      • leitseitenmacher says

        @wpbeginner

        well i allready noticed that.

        but the question was: is it possible in wordpress to register a standard post thumbnail via php code so you can see it in the backend?

        • wpbeginner says

          @leitseitenmacher Great find. Again, there is no HYPE that we are trying to create. It is impossible to keep track of what exists in the plugin sphere of WordPress because there are thousands.Just tested out that plugin… It doesn’t register those thumbnails in the database of each post. It is just hooking and giving you a visual display of what you selected in the plugins setting.

          If that is what you want, then sure.

          The article above accomplishes exactly the same thing without going the extra lengths of visually displaying. In most sites the fallback is usually the site logo. So you don’t really need to see it. But we will do a writeup on the plugin you found. Thanks for the suggestion :)

  28. gal1982 says

    Excellent solutions, i was looking for that for a while

    Is there a way to change the resize the image?

    I have tried for example:

    $image=wp_get_attachment_image($num, ‘medium’);

    But it doesn’t effects the image size. any idea?

  29. milohuang says

    Nice tutorial. Have test the first method but it did not seem to work. Check the HTML and the default thumb does not exist (no img tag was found). However, if I use the Default Post Thumbnail plugin, it works. Any help? Running 3.2 locally. Thank you!

  30. wp_smith says

    Hello,

    I have written a plugin, <a href=”http://wpsmith.net/go/genesis-featured-images”>Genesis Featured Images</a>, that will do this for the <a href=”http://wpsmith.net/go/genesis”>Genesis Framework</a>. I’d love to hear your thoughts!?

  31. sleepingsun says

    Hello !

    Thanks a lot for this useful tip. How would I make the same function to work in RSS feeds please ? If a post thumbnail has been set : use it, otherwise : use the first image attached to the post.

    Any help would be much appreciated !

Deixe uma resposta

Obrigado por deixar um comentário. Lembre-se de que todos os comentários são moderados de acordo com nossos política de comentários, e seu endereço de e-mail NÃO será publicado. NÃO use palavras-chave no campo do nome. Vamos ter uma conversa pessoal e significativa.