为WordPress添加分类、标签自定义标题

  • A+
所属分类:wordpress
摘要

为WordPress分类、标签添加自定义的好处在于可以做网站的搜索引擎优化(有利于WordPress SEO),又可以提升用户体验。

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

从搜索引擎优化角度来说,这样简短的标题也没有什么不好,但是,从整体上来说,并没有对网站进行好的搜索引擎优化。而为WordPress采用自定义标题的方式,可以适当增加关键词的标题,既能吸引用户,又能对搜索引擎展现良好。

经过一番搜索和摸索,以及阅读 WordPress 文档,总算是找到了解决办法。在这里,不得不说一下,技术性的问题,一定要记得谷歌,记住:谷歌!很早之前用度娘查找,收获不大,当然,并不是说没有参考价值,但是却相对要小。用谷歌,这个问题很快让我找到了方案。

为WordPress添加分类、标签自定义标题

为WordPress添加分类、标签自定义标题

为WordPress添加分类、标签自定义标题的实现方法:

1、把下面的代码保存复制成一个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_tagreturn $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 } ?>

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

文章来源于:WPGeek WordPress(微信号)

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

目前评论:6   其中:访客  5   博主  1

    • avatar 憧憬Licoy 0

      不知博主是否知道如何自定义数据库字段或表

      • avatar 张浩浩 0

        学习了,感谢博主分享。

        • avatar 平步青云 0

          弱弱的问一下第三步怎么添加到主题中

            • avatar 单触角蚂蚁 Admin

              @平步青云 需要根据主题Title的位置添加~

                • avatar LEO 0

                  @单触角蚂蚁 抱歉我想问一下第三步骤我添加到title里面,显示不正确,自己技术有限,但是特别想要这个功能。我用的大前端的D8主题,试了一个晚上了,还是没弄好。

              • avatar 耐腐蚀泵 0

                亲测可用,已调整。谢谢博主!