WordPress教程

WordPress 主题添加分类/标签自定义标题

阿里云

我们知道为 WordPress 分类、标签添加自定义的好处在于可以做网站的搜索引擎优化(有利于 WordPress SEO),又可以提升用户体验。如果不使用自定义标题的话,即文章的标题即为网页搜索引擎抓取的标题,分类标题,需要简短一点,否则用户打开分类目录时会显得很混乱。

从搜索引擎优化角度来说,这样简短的标题也没有什么不好,但是,从整体上来说,并没有对网站进行好的搜索引擎优化。而为 WordPress 采用自定义标题的方式,可以适当增加关键词的标题,既能吸引用户,又能对搜索引擎展现良好。经过一番搜索和摸索,以及阅读 WordPress 文档,总算是找到了解决办法。在这里,不得不说一下,技术性的问题,一定要记得谷歌,记住:谷歌!很早之前用度娘查找,收获不大,当然,并不是说没有参考价值,但是却相对要小。用谷歌,这个问题很快让我找到了方案。

为 WordPress 添加分类、标签自定义标题的实现方法:把下面的代码保存复制成一个 PHP 文件,比如:title.php

也想出现在这里?联系我们
创客主机
  1.     <?php
  2.     //自定义分类标题
  3.     class zm_wp_title{
  4.         function __construct(){
  5.         // 分类
  6.             add_action( 'category_add_form_fields', array( $this, 'add_tax_title_field' ) );
  7.             add_action( 'category_edit_form_fields', array( $this, 'edit_tax_title_field' ) );
  8.             add_action( 'edited_category', array( $this, 'save_tax_meta' ), 10, 2 );
  9.             add_action( 'create_category', array( $this, 'save_tax_meta' ), 10, 2 );
  10.         // 标签
  11.             add_action( 'post_tag_add_form_fields', array( $this, 'add_tax_title_field' ) );
  12.             add_action( 'post_tag_edit_form_fields', array( $this, 'edit_tax_title_field' ) );
  13.             add_action( 'edited_post_tag', array( $this, 'save_tax_meta' ), 10, 2 );
  14.             add_action( 'create_post_tag', array( $this, 'save_tax_meta' ), 10, 2 );
  15.         }
  16.         public function add_tax_title_field(){
  17.     ?>
  18.             <div class="form-field term-title-wrap">
  19.                 <label for="term_meta[tax_zm_title]">自定义标题</label>
  20.                 <input type="text" name="term_meta[tax_zm_title]" id="term_meta[tax_zm_title]" value="" />
  21.                 <p class="description">搜索引擎优化自定义标题,不填写即为默认标题</p>
  22.             </div>
  23.     <?php
  24.         } // add_tax_title_field
  25.         public function edit_tax_title_field( $term ){
  26.             $term_id = $term->term_id;
  27.             $term_meta = get_option( "zm_taxonomy_$term_id" );
  28.             $zm_title = $term_meta['tax_zm_title'] ? $term_meta['tax_zm_title'] : '';
  29.     ?>
  30.             <tr class="form-field term-title-wrap">
  31.                 <th scope="row">
  32.                     <label for="term_meta[tax_zm_title]">自定义标题</label>
  33.                     <td>
  34.                         <input type="text" name="term_meta[tax_zm_title]" id="term_meta[tax_zm_title]" value="<?php echo $zm_title; ?>" />
  35.                         <p class="description">搜索引擎优化自定义标题,不填写即为默认标题</p>
  36.                     </td>
  37.                 </th>
  38.             </tr>
  39.     <?php
  40.         } // edit_tax_title_field
  41.         public function save_tax_meta( $term_id ){
  42.             if ( isset( $_POST['term_meta'] ) ) {
  43.                 $t_id = $term_id;
  44.                 $term_meta = array();
  45.                 $term_meta['tax_zm_title'] = isset ( $_POST['term_meta']['tax_zm_title'] ) ? $_POST['term_meta']['tax_zm_title'] : '';
  46.                 update_option( "zm_taxonomy_$t_id", $term_meta );
  47.             } // if isset( $_POST['term_meta'] )
  48.         } // save_tax_meta
  49.     } // zm_wp_title
  50.     $wptt_tax_title = new zm_wp_title();
  51.     function the_zm_title() {
  52.         $category = get_the_category();
  53.         $term_id = $category[0]->cat_ID;
  54.         $term_meta = get_option( "zm_taxonomy_$term_id" );
  55.         $tax_zm_title = $term_meta['tax_zm_title'] ? $term_meta['tax_zm_title'] : '';
  56.         echo $tax_zm_title;
  57.     }
  58.     function get_current_tag_id() {
  59.         $current_tag = single_tag_title('', false);
  60.         $tags = get_tags();
  61.         foreach($tags as $tag) {
  62.             if($tag->name == $current_tag) return $tag->term_id;
  63.         }
  64.     }
  65.     function zm_tag_title() {
  66.         $term_id = get_current_tag_id();
  67.         $term_meta = get_option( "zm_taxonomy_$term_id" );
  68.         $zm_tag_title = $term_meta['tax_zm_title'] ? $term_meta['tax_zm_title'] : '';
  69.         echo $zm_tag_title;
  70.     }
  71.     ?>

2、把 title.php 文件引入到主题函数 functions.php 中

  1.     //自定义标题
  2.     require get_template_directory() . '/title.php';

完成上面的步骤之后,基本上后台就已经出现了分类、标签自定义标题填写框,接下来需要做的就是前台的调用。

3、把下面的代码放到自定义 Title 中 ,这个需要根据主题情况。

分类标题:

  1. <?php if ( is_category() ) { ?><title><?php $title = the_zm_title(); echo ($title) ? ''.$title.'' : single_cat_title(); ?> - <?php bloginfo('name'); ?></title><?php } ?>

标签标题:

  1. <?php if ( is_tag() ) { ?><title><?php  $title = zm_tag_title(); echo ($title) ? ''.$title.'' : single_tag_title("", true); ?> - <?php bloginfo('name'); ?></title><?php } ?>

非常简单,就是判断自定义标题有没有输入,如果没有的话,即显示原标题,如果有自定义标题,则显示自定义标题。

WordPress 主题添加分类/标签自定义标题

已有 574 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!