国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > CMS > Wordpress > 正文

WordPress中獲取頁面鏈接和標題的相關PHP函數(shù)用法解析

2024-09-07 00:48:11
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了WordPress中獲取頁面鏈接和標題的相關PHP函數(shù)用法解析,分別為get_permalink()和wp_title()函數(shù)的使用,需要的朋友可以參考下。

get_permalink()(獲取文章或頁面鏈接)

get_permalink() 用來根據(jù)固定連接返回文章或者頁面的鏈接。在獲取鏈接時 get_permalink() 函數(shù)需要知道要獲取的文章的 ID,如果在循環(huán)中則自動默認使用當前文章。

用法:

get_permalink( $id, $leavename );

參數(shù):

$id

(混合)(可選)文章或者頁面的 ID(整數(shù));還可以是文章對象。

默認值:在循環(huán)中自動調用當前的文章

$leavename

(布爾)(可選)轉化成鏈接是是否忽略文章別名。如果設置成 True,那么將返回 http://www.example.com/%postname% 而不是 http://www.example.com/my-post-name

默認值:None

返回值

(字符串 | 布爾)成功獲取鏈接則返回鏈接,失敗則返回 False.

例子:

根據(jù) ID 獲取文章或頁面的鏈接:

<a href="<?php echo get_permalink( 268 ); ?>">獲取指定 ID 的文章或頁面鏈接</a>

循環(huán)中獲取當前文章的鏈接:

<?php echo get_permalink(); ?>

根據(jù)頁面標題獲取頁面鏈接:

<a href="<?php echo esc_url( get_permalink( get_page_by_title( '留言板' ) ) ); ?>">留言板</a>

其它

此函數(shù)位于:wp-includes/link-template.php

wp_title()(獲取網頁標題)

wp_title() 用來獲取當前網頁的標題,也就是 title 標簽里邊的內容。

wp_title() 能在不同的頁面自動生成不同的標題(比如首頁就是網站標題、文章頁就是文章標題)。WordPress 官方的主題都在使用這個函數(shù)生成標題,但是在國內的主題中卻總是被忽視(因為默認情況下這個函數(shù)對 SEO 并不是太好)。

我還是推薦使用這個函數(shù)調用標題,更加符合主題開發(fā)規(guī)范,如果你要讓他變的更加符合 SEO,可以使用過濾器優(yōu)化一下,本文結尾有優(yōu)化方法。

用法

wp_title( $sep, $display, $seplocation );

參數(shù)

$sep

(字符串)(可選)標題內容的分隔符,一般設置成 “|” 或者 “-”。

默認值:&raquo;(»)

$display

(布爾)(可選)是否直接打印標題,如果設置成 False 則返回標題,可以存儲到變量里。

默認值:True(直接打印輸出)

$seplocation

(字符串)(可選)分隔符所在位置,左邊還是右邊,如果傳遞 “right” 則為右邊,其它任何內容都是左邊。

默認值:空字符串(左邊)

返回值

(字符串)如果 $display 參數(shù)設置成 False,才能返回標題的內容,根據(jù)不同的標題會返回不同的內容,默認情況下返回的內容是這樣的:

文章頁:文章標題

日期頁:日期

分類頁:分類標題

作者頁:作者名字

如果你想更加詳細的了解,可以閱讀下邊的函數(shù)源碼:

  1. /** 
  2.  * Display or retrieve page title for all areas of blog. 
  3.  * 
  4.  * By default, the page title will display the separator before the page title, 
  5.  * so that the blog title will be before the page title. This is not good for 
  6.  * title display, since the blog title shows up on most tabs and not what is 
  7.  * important, which is the page that the user is looking at. 
  8.  * 
  9.  * There are also SEO benefits to having the blog title after or to the 'right' 
  10.  * or the page title. However, it is mostly common sense to have the blog title 
  11.  * to the right with most browsers supporting tabs. You can achieve this by 
  12.  * using the seplocation parameter and setting the value to 'right'. This change 
  13.  * was introduced around 2.5.0, in case backwards compatibility of themes is 
  14.  * important. 
  15.  * 
  16.  * @since 1.0.0 
  17.  * 
  18.  * @param string $sep Optional, default is '»'. How to separate the various items within the page title. 
  19.  * @param bool $display Optional, default is true. Whether to display or retrieve title. 
  20.  * @param string $seplocation Optional. Direction to display title, 'right'. 
  21.  * @return string|null String on retrieve, null when displaying. 
  22.  */ 
  23. function wp_title($sep = '»'$display = true, $seplocation = '') { 
  24.   global $wp_locale
  25.    
  26.   $m = get_query_var('m'); 
  27.   $year = get_query_var('year'); 
  28.   $monthnum = get_query_var('monthnum'); 
  29.   $day = get_query_var('day'); 
  30.   $search = get_query_var('s'); 
  31.   $title = ''
  32.    
  33.   $t_sep = '%WP_TITILE_SEP%'// Temporary separator, for accurate flipping, if necessary 
  34.    
  35.   // If there is a post 
  36.   if ( is_single() || ( is_home() && !is_front_page() ) || ( is_page() && !is_front_page() ) ) { 
  37.     $title = single_post_title( '', false ); 
  38.   } 
  39.    
  40.   // If there's a post type archive 
  41.   if ( is_post_type_archive() ) { 
  42.     $post_type = get_query_var( 'post_type' ); 
  43.     if ( is_array$post_type ) ) 
  44.       $post_type = reset( $post_type ); 
  45.     $post_type_object = get_post_type_object( $post_type ); 
  46.     if ( ! $post_type_object->has_archive ) 
  47.       $title = post_type_archive_title( '', false ); 
  48.   } 
  49.    
  50.   // If there's a category or tag 
  51.   if ( is_category() || is_tag() ) { 
  52.     $title = single_term_title( '', false ); 
  53.   } 
  54.    
  55.   // If there's a taxonomy 
  56.   if ( is_tax() ) { 
  57.     $term = get_queried_object(); 
  58.     if ( $term ) { 
  59.       $tax = get_taxonomy( $term->taxonomy ); 
  60.       $title = single_term_title( $tax->labels->name . $t_sep, false ); 
  61.     } 
  62.   } 
  63.    
  64.   // If there's an author 
  65.   if ( is_author() && ! is_post_type_archive() ) { 
  66.     $author = get_queried_object(); 
  67.     if ( $author ) 
  68.       $title = $author->display_name; 
  69.   } 
  70.    
  71.   // Post type archives with has_archive should override terms. 
  72.   if ( is_post_type_archive() && $post_type_object->has_archive ) 
  73.     $title = post_type_archive_title( '', false ); 
  74.    
  75.   // If there's a month 
  76.   if ( is_archive() && !emptyempty($m) ) { 
  77.     $my_year = substr($m, 0, 4); 
  78.     $my_month = $wp_locale->get_month(substr($m, 4, 2)); 
  79.     $my_day = intval(substr($m, 6, 2)); 
  80.     $title = $my_year . ( $my_month ? $t_sep . $my_month : '' ) . ( $my_day ? $t_sep . $my_day : '' ); 
  81.   } 
  82.    
  83.   // If there's a year 
  84.   if ( is_archive() && !emptyempty($year) ) { 
  85.     $title = $year
  86.     if ( !emptyempty($monthnum) ) 
  87.       $title .= $t_sep . $wp_locale->get_month($monthnum); 
  88.     if ( !emptyempty($day) ) 
  89.       $title .= $t_sep . zeroise($day, 2); 
  90.   } 
  91.    
  92.   // If it's a search 
  93.   if ( is_search() ) { 
  94.     /* translators: 1: separator, 2: search phrase */ 
  95.     $title = sprintf(__('Search Results %1$s %2$s'), $t_sepstrip_tags($search)); 
  96.   } 
  97.    
  98.   // If it's a 404 page 
  99.   if ( is_404() ) { 
  100.     $title = __('Page not found'); 
  101.   } 
  102.    
  103.   $prefix = ''
  104.   if ( !emptyempty($title) ) 
  105.     $prefix = " $sep "
  106.    
  107.   /** 
  108.    * Filter the parts of the page title. 
  109.    * 
  110.    * @since 4.0.0 
  111.    * 
  112.    * @param array $title_array Parts of the page title. 
  113.    */ 
  114.   $title_array = apply_filters( 'wp_title_parts'explode$t_sep$title ) ); 
  115.    
  116.    // Determines position of the separator and direction of the breadcrumb 
  117.   if ( 'right' == $seplocation ) { // sep on right, so reverse the order 
  118.     $title_array = array_reverse$title_array ); 
  119.     $title = implode( " $sep "$title_array ) . $prefix
  120.   } else { 
  121.     $title = $prefix . implode( " $sep "$title_array ); 
  122.   } 
  123.    
  124.   /** 
  125.    * Filter the text of the page title. 
  126.    * 
  127.    * @since 2.0.0 
  128.    * 
  129.    * @param string $title    Page title. 
  130.    * @param string $sep     Title separator. 
  131.    * @param string $seplocation Location of the separator (left or right). 
  132.    */ 
  133.   $title = apply_filters( 'wp_title'$title$sep$seplocation ); 
  134.    
  135.   // Send it out 
  136.   if ( $display ) 
  137.     echo $title
  138.   else 
  139.     return $title
  140.    

很顯然默認情況下標題是比較簡陋的,對 SEO 并不是很友好。

例子:

<title><?php wp_title( '|', true, 'right' ); ?></title>

其它

標題可以使用 wp_title 過濾器定制,此函數(shù)位于:wp-includes/general-template.php

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉沽区| 铜梁县| 贡山| 贺兰县| 宜昌市| 岳阳县| 揭西县| 从江县| 绥中县| 公安县| 田东县| 伊吾县| 桑日县| 沅陵县| 太保市| 手游| 乐至县| 盱眙县| 青河县| 湖南省| 勃利县| 富裕县| 彭阳县| 阜新市| 榕江县| 凤山市| 翁牛特旗| 长春市| 平邑县| 黔西| 芦溪县| 健康| 宁乡县| 连州市| 广元市| 赣榆县| 安阳县| 石林| 清原| 历史| 清原|