Algunas muy buenas respuestas introductorias aquí.
Básicamente, get_template_part()
permite a los desarrolladores de temas configurar un orden de especificidad de los archivos de plantilla. Piénselo de manera similar a la especificidad que se aplica a los selectores CSS. Al diseñar algo, debe comenzar con el mínimo de especificidad, de modo que pueda anularse fácilmente en partes de un diseño que requieren atención individual.
Entonces, por ejemplo, estás diseñando un blog y creas un archivo loop.php que funciona bien para marcar publicaciones. Pero planifica con anticipación, y luego lo llama en sus archivos de plantilla con especificadores de contexto adicionales: por ejemplo, en la página de índice, llama get_template_part( 'loop', 'index' );
, en la plantilla única, llama get_template_part( 'loop', 'single' );
, en páginas de archivo, llama get_template_part( 'loop', 'archive' );
, etc. Esto hace que sea muy fácil en el futuro cuando decidas marcar el bucle en tus páginas de archivo de manera diferente a la página de inicio: solo crea una plantilla loop-archive.php y se usará en lugar del loop genérico.php .
Pero la magia detrás get_template_part()
está en la función locate_template()
, que comprueba primero el directorio del tema, luego el directorio principal (si existe) para el archivo nombrado. Esto es muy útil para el desarrollo de complementos. En uno de mis complementos, defino un tipo de publicación personalizada y creé un archivo de plantilla de bucle para ese tipo de publicación personalizada en mi directorio de complementos. Pero ... quiero permitir que los temas que usan mi complemento anulen mi marcado si así lo desean. Aquí es donde locate_template()
realmente funciona maravillas.
locate_template($template_names, $load = false, $require_once = true )
buscará cada uno de los nombres en la matriz $ template_names en el directorio de la hoja de estilo, luego en el directorio de la plantilla. Pasar 'verdadero' como el argumento $ load significa que requerirá el primer archivo encontrado y devolverá una cadena vacía si no se encontró un archivo de plantilla. Entonces puedo hacer algo como esto en mi plugin:
if ( '' === locate_template( 'loop-mycustomposttype.php', true, false ) )
include( 'loop-mycustomposttype.php' );
... lo que con suerte debería facilitar mucho a los desarrolladores de temas personalizar mi complemento con solo incluir un archivo llamado loop-mycustomposttype.php en su tema.