Geek the Planet


PHP no image

Published on Septiembre 20th, 2008 | by Angelfire

5

Mostrar los posts mas comentados sin usar un plugin

Ultimamente me he vuelto partidario de no usar plugins, por esta razón he estado buscando opciones alternativas al uso de plugins, la razón, creo que la más básica y sencilla es evitar la sobrecarga de peticiones al servidor, de esta manera agilizar la carga de mi blog.

Hoy gracias a Ayuda WordPress, me he encontrado con esta excelente función que nos permite mostrar cuales han sido los post más comentados, este debe ser unos de los widgets imprecindibles en nuestra sidebar, de esta manera para los usuarios será fácil saber cual es el “boom” del momento en nuestro blog o cual es el post más interesante.

Yo le he hecho un par de arreglito básicos para mejorar el orden y evitar el error que inevitablemente se mostrará en en la función hecha por Fernando Tellado, lo primero es que he creado una pagina especial llamada postmascoment.php, que incluye el siguiente código:


<?php
function posts_mas_comentados($no_posts = 5, $before = '<li>', $after = '</li>', $show_pass_post = false, $duration='') {
	global $wpdb;
	$request = "SELECT ID, post_title, COUNT($wpdb->comments.comment_post_ID) AS 'comment_count' FROM $wpdb->posts, $wpdb->comments";
	$request .= " WHERE comment_approved = '1' AND $wpdb->posts.ID=$wpdb->comments.comment_post_ID AND post_status = 'publish'";
	if(!$show_pass_post) $request .= " AND post_password =''";
	if($duration !="") {
		$request .= " AND DATE_SUB(CURDATE(),INTERVAL ".$duration." DAY) <post_date ";
	}
	$request .= " GROUP BY $wpdb->comments.comment_post_ID ORDER BY comment_count DESC LIMIT $no_posts";
	$posts = $wpdb->get_results($request);
	$output = '';
	if ($posts) {
		foreach ($posts as $post) {
			$post_title = stripslashes($post->post_title);
			$comment_count = $post->comment_count;
			$permalink = get_permalink($post->ID);
			$output .= $before . '<a href="' . $permalink . '" >' . $post_title . '</a> (' . $comment_count.')' . $after;
			}
	} else {
		$output .= $before . "No hay nada" . $after;
	}
		echo $output;
}
?>


Lo más común es que el widget de los más comentados lo queramos mostrar en la sidebar, así que debemos incluir esta página y luego invocar la función que acabamos de crear:


<? include (TEMPLATEPATH . '/postmascomentados.php'); ?>

Luego para mostrar los posts en una lista desordenada, debemos crear un widget:


        <div>
		<h3>Post mas comentados</h3>
		<ul>
			<?php posts_mas_comentados(); ?>
		</ul>
        </div>

Y listo, sin necesidad de plugins :)

Tags: ,


About the Author

Systems Engineering, Computer Systems Specialist, Social Engineering Specialist. Social Media Analyzer. Usability and SEO enthusiasm (Este es mi perfil de Twitter...)



5 Responses to Mostrar los posts mas comentados sin usar un plugin

  1. Héctor says:

    Hola,

    interesante el tema, yo uso varios plugins y los consideré mejor que un widget porque permiten cargar la página más rápido, si entiendo bien, tu mencionas que no usar plugins te permite:”evitar la sobrecarga de peticiones al servidor, de esta manera agilizar la carga de mi blog”.

    Me pregunto será que estoy equivocado en mi razonamiento?

    Saludos,

  2. Angelfire says:

    @Héctor: Mira, yo conozco 2 plugins que cumplen con la misma función, uno pesa 18kb y el otro pesa 54kb, la función que aparece arriba tan sólo pesa 1.1kb, mira que la reducción en peso es bastante grande, está claro que los plugins vienen con más funciones y eso, pero lo que buscamos es algo básico, posiblemente 54kb no sean mucho, pero eso suma.

  3. MikeM says:

    Hola Angelfire! He hecho lo que explicas, pero no sé como crear el widget que dices al final con ese código. Que tengo que hacer? Crear otro archivo php y subirlo a alguna parte de la carpeta de WordPress?
    Gracias por adelantado y a ver si me puedes contestar porque me interesa mucho el tema!

  4. Erwin says:

    Esto también funciona en Blogspot?

Back to Top ↑
  • Comentarios recientes

  • Miniposts

    • iOS 8 disponible para descargar

      Hoy se anunció de manera oficial iOS 8, la fecha de llegada será el próximo 17 de septiembre. En iPhonehacks han recopilado los enlaces de descarga directo para los diferentes dispositivos que soportan la nueva versión del sistema operativo. Así que para quienes no desean esperar, ya pueden acceder a la versión Golden Master ...

    • Festigame Colombia 2014

      El festival de videojuegos, cultura gamer y entretenimiento familiar más grande de América Latina ha llegado a nuestro país. Festigame que es un evento creado en Chile en 2012, se ha convertido en el evento anual donde las marcas más importantes de la industria presentan sus últimos productos en el ...

    • Peter Griffin también tiene cuenta en Instagram

      El protagonista de la serie de humor, Padre de Familia, Peter Griffin ha inaugurado su presencia en la red social de fotografía con divertidas fotografías de su vida, y a pesar de ser un personaje de ficción ya ha superado los 200.000 seguidores en tan sólo dos semanas. Son unas fotos bastante divertidas, las ...

    • Manual y documentación de Node.js para Android

      Node.js se ha venido haciendo bastante popular en los últimos años, cada vez son más los usos que como desarrolladores web le damos a esta tecnología. La siguiente aplicación es el manual y la documentación de Node.js, que contiene los siguientes temas: About these Docs Synopsis Assertion Testing Buffer C/C++ Addons Child Processes Cluster Console Crypto Debugger DNS Domain Events File System Globals HTTP HTTPS Modules Net OS Path Process Punycode Query Strings Readline REPL Stream String Decoder Timers TLS/SSL TTY UDP/Datagram URL Utilities VM ZLIB

    • Star Wars Traceroute

      ¿Qué pasa cuando un ingeniero está muy desocupado? pues pasan cosas como esta: Mac y Linux Van a la consola y escriben: traceroute 216.81.59.173 Windows Buscan el CMD y escriben: tracert 216.81.59.173 El resultado es interesante y sorprendente. Si quieren ver la salida de la ejecución del comando, pueden ver el gist Ver más: Beagle Network

  • Comunicados - Notas de Prensa