您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)wp_title()函數(shù)怎么在WordPress中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
wp_title 函數(shù)在 WordPress 中是用來(lái)顯示文章、頁(yè)面、分類(lèi)等等等等標(biāo)題的一個(gè)函數(shù),但在首頁(yè)索引,該函數(shù)將不顯示任何的東西。該函數(shù)在 WordPress 官方主題中一直被使用,但目前很多定制的主題中這個(gè)函數(shù)總是為忽視。
函數(shù)意義詳解
wp_title 函數(shù)用來(lái)顯示頁(yè)面的標(biāo)題,如在文章頁(yè)面,則顯示文章標(biāo)題;在分類(lèi)頁(yè)面,則顯示分類(lèi)名稱(chēng),但在首頁(yè)索引,該函數(shù)將不顯示任何的東西。
有點(diǎn)像 WordPress 中的 get_the_title 和 single_cat_title()這兩個(gè)函數(shù)的自適應(yīng)用法(自動(dòng)判斷是頁(yè)面、文章還是分類(lèi)、歸檔、標(biāo)簽)。
函數(shù)聲明
有點(diǎn)長(zhǎng),希望您能耐心看一遍,哪怕只有那么一遍。
/** * Display or retrieve page title for all areas of blog. * * By default, the page title will display the separator before the page title, * so that the blog title will be before the page title. This is not good for * title display, since the blog title shows up on most tabs and not what is * important, which is the page that the user is looking at. * * There are also SEO benefits to having the blog title after or to the 'right' * or the page title. However, it is mostly common sense to have the blog title * to the right with most browsers supporting tabs. You can achieve this by * using the seplocation parameter and setting the value to 'right'. This change * was introduced around 2.5.0, in case backwards compatibility of themes is * important. * * @since 1.0.0 * * @param string $sep Optional, default is '»'. How to separate the various items within the page title. * @param bool $display Optional, default is true. Whether to display or retrieve title. * @param string $seplocation Optional. Direction to display title, 'right'. * @return string|null String on retrieve, null when displaying. */ function wp_title($sep = '»', $display = true, $seplocation = '') { global $wpdb, $wp_locale; $m = get_query_var('m'); $year = get_query_var('year'); $monthnum = get_query_var('monthnum'); $day = get_query_var('day'); $search = get_query_var('s'); $title = ''; $t_sep = '%WP_TITILE_SEP%'; // Temporary separator, for accurate flipping, if necessary // If there is a post if ( is_single() || ( is_home() && !is_front_page() ) || ( is_page() && !is_front_page() ) ) { $title = single_post_title( '', false ); } // If there's a category or tag if ( is_category() || is_tag() ) { $title = single_term_title( '', false ); } // If there's a taxonomy if ( is_tax() ) { $term = get_queried_object(); $tax = get_taxonomy( $term->taxonomy ); $title = single_term_title( $tax->labels->name . $t_sep, false ); } // If there's an author if ( is_author() ) { $author = get_queried_object(); $title = $author->display_name; } // If there's a post type archive if ( is_post_type_archive() ) $title = post_type_archive_title( '', false ); // If there's a month if ( is_archive() && !empty($m) ) { $my_year = substr($m, 0, 4); $my_month = $wp_locale->get_month(substr($m, 4, 2)); $my_day = intval(substr($m, 6, 2)); $title = $my_year . ( $my_month ? $t_sep . $my_month : '' ) . ( $my_day ? $t_sep . $my_day : '' ); } // If there's a year if ( is_archive() && !empty($year) ) { $title = $year; if ( !empty($monthnum) ) $title .= $t_sep . $wp_locale->get_month($monthnum); if ( !empty($day) ) $title .= $t_sep . zeroise($day, 2); } // If it's a search if ( is_search() ) { /* translators: 1: separator, 2: search phrase */ $title = sprintf(__('Search Results %1$s %2$s'), $t_sep, strip_tags($search)); } // If it's a 404 page if ( is_404() ) { $title = __('Page not found'); } $prefix = ''; if ( !empty($title) ) $prefix = " $sep "; // Determines position of the separator and direction of the breadcrumb if ( 'right' == $seplocation ) { // sep on right, so reverse the order $title_array = explode( $t_sep, $title ); $title_array = array_reverse( $title_array ); $title = implode( " $sep ", $title_array ) . $prefix; } else { $title_array = explode( $t_sep, $title ); $title = $prefix . implode( " $sep ", $title_array ); } $title = apply_filters('wp_title', $title, $sep, $seplocation); // Send it out if ( $display ) echo $title; else return $title; }
用法
<?php wp_title( $sep, $echo, $seplocation ); ?>
參數(shù)詳解
$sep:分隔符;
$echo:是否顯示;
$seplocation:分隔符所在位置(左還是右,只接受'right',如果不是right自動(dòng)判定為左)
總結(jié)
WordPress 中相同功能的函數(shù)有很多,都是從基層到高級(jí)不斷的經(jīng)過(guò)封裝最后到達(dá)使用層的,當(dāng)然如果我們需要一些靈活用法的話(huà),我們可以直接用中間那層的函數(shù),如果我們懶的話(huà)我們可以直接使用最高級(jí)的那層函數(shù),諸如本函數(shù) wp_title ,其實(shí)這個(gè)函數(shù)我們從源代碼來(lái)看, wp 替我們針對(duì) 分類(lèi)、標(biāo)簽、文章、歸檔、作者、頁(yè)面等多種類(lèi)型的頁(yè)面進(jìn)行了判斷,并根據(jù)不同頁(yè)面調(diào)用不同的標(biāo)題函數(shù)來(lái)達(dá)到目的。
如果有時(shí)間,您可以對(duì)下面幾個(gè)函數(shù)進(jìn)行深入研究一下,一遍更靈活的進(jìn)行seo
single_post_title 文章頁(yè)面提取標(biāo)題的函數(shù)
single_term_title tag(標(biāo)簽)、cat(分類(lèi))、日期、提取標(biāo)題的函數(shù) 類(lèi)似于 single_cat_title()函數(shù)
get_queried_object 作者頁(yè)面提取對(duì)象的函數(shù)(對(duì)象中有作者名)
post_type_archive_title()規(guī)檔等等提取標(biāo)題的函數(shù)
看完上述內(nèi)容,你們對(duì)wp_title()函數(shù)怎么在WordPress中使用有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。