首页 > 运营 > 建站经验 > 正文

WordPress主题制作全过程(五):制作header.php

2019-10-15 22:20:06
字体:
来源:转载
供稿:网友

 你可以尝试用文本编辑器打开从WordPress主题制作全过程(三):HTML静态模板制作下载到的 .html 文件,不知道你有没有发现他们头部的代码都非常的相似呢?其实我们可以提取这部分相似的代码,放到一个单独的文件header.php中,各个页面想用这部分代码的时候再用php的include包含进去,省的每个页面里面都要写这部分代码,更改起来也可以达到一改全改的目的。

     再次提醒:如果你不打算动手编写代码,这个系列教程就别看了,对你无益!

     接着我们上次创建的主题目录wp-content/themes/Aurelius,在该目录下新建一个php文件header.php,我们提取出index.php中的头部代码复制粘贴到header.php中,下面是的代码就是目前header.php中的所有代码了(当然不同主题的头部代码都是不一样,在你实际的项目中可以自定决定):

 
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
  2. <html xmlns="http://www.w3.org/1999/xhtml"> 
  3. <head profile="http://gmpg.org/xfn/11"> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  5. <title>Aurelius | Blog</title> 
  6. <!-- Stylesheets --> 
  7. <link rel="stylesheet" href="./style.css" type="text/css" media="screen" /> 
  8. </head> 
  9. <body> 
  10. <div id="wrapper" class="container_12 clearfix"> 
  11.     <!-- Text Logo --> 
  12.     <h1 id="logo" class="grid_4">Aurelius</h1> 
  13.     <!-- Navigation Menu --> 
  14.     <ul id="navigation" class="grid_8"> 
  15.         <li><a href="contact.html"><span class="meta">Get in touch</span><br /> 
  16.             Contact Us</a></li> 
  17.         <li><a href="blog.html" class="current"><span class="meta">Latest news</span><br /> 
  18.             Blog</a></li> 
  19.         <li><a href="index.html"><span class="meta">Homepage</span><br /> 
  20.             Home</a></li> 
  21.     </ul> 
  22.     <div class="hr grid_12 clearfix">&nbsp;</div> 
  23.     <!-- Caption Line --> 
  24.     <h2 class="grid_12 caption clearfix">Our <span>blog</span>, keeping you up-to-date on our latest news.</h2> 
  25.     <div class="hr grid_12 clearfix">&nbsp;</div> 




     再用文本编辑器打开index.php、archive.php、contact.php、full_width.php、page.php和single.php,删掉以上类似代码,改成:

 
  1. <?php get_header(); ?> 


     好,现在打开你的测试博客主页,看看我们制作的主题是否还可以正常工作,答案是可以的,跟原来几乎没什么两样,但还是一片混乱。get_header()就相当于将header.php中的代码拷贝到当前的php文件。接下来,我们将仔细探讨header.php中的动态内容。header.php将会被所有的模板页面(主页、分类页、页面、标签页等)所包含,所以header.php中代码应该是动态,适合不同页面的,所以这里面需要用到PHP代码,而不是单纯的HTML。下面让我们一起来修改header.php:

1、更改<title>

     我们都知道不同页面的title都是不一样,而且title的设置还会直接影响到SEO的效果,所以这里应该谨慎设置。下面提供一种SEO优化的title写法,将<title>Aurelius | Blog</title>改成:

 
  1. <title><?php if ( is_home() ) { 
  2.         bloginfo('name'); echo " - "; bloginfo('description'); 
  3.     } elseif ( is_category() ) { 
  4.         single_cat_title(); echo " - "; bloginfo('name'); 
  5.     } elseif (is_single() || is_page() ) { 
  6.         single_post_title(); 
  7.     } elseif (is_search() ) { 
  8.         echo "搜索结果"echo " - "; bloginfo('name'); 
  9.     } elseif (is_404() ) { 
  10.         echo '页面未找到!'
  11.     } else { 
  12.         wp_title('',true); 
  13.     } ?></title> 



     以上添加的php代码运用了条件判断,针对不同的页面采用不同title,这里解释一下这几个条件标签。

  • is_home() :当前页面为主页时返回true
  • is_category():当前页面为分类页时返回true
  • is_single():当前页面为单文章页时返回true
  • is_page():当前页面为单页面时返回true
  • 更详细的内容参阅WordPress文档:Template Tags/wp list pages
  • WordPress主题制作全过程(五):制作header.php


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表