Wordpress主题开发之index.php

简介: 本文介绍了 WordPress 主题开发中页面结构与模板文件的使用方法。通过 header.php、sidebar.php、footer.php 和 index.php 等模板文件,实现网站模块化设计,便于统一管理和代码重用。Header 部分包含 logo、导航条等;Content 展示主体内容;Side bar 显示推荐信息或广告;Footer 则呈现版权和备案信息等内容。文章还提供了各模板文件的具体代码示例,帮助开发者快速理解和应用 WordPress 模板机制。

wordpress主题开发过程中,通过一个简单的 index.php 文件,显示了一个网站首页。 实际上,Wordpress 并不是通过某一个文件来显示内容的,而是一堆模板文件组合显示。

页面结构

网站的风格千姿百态,我选取内容型网站(如简书,知乎等)作为样例。图片或者视频型的网站大都不是这样设计的,但是某些地方又有相通之处

可以将网站划分为以下几个模块:

  • Header 网站的头部:显示 logo、导航条、搜索框等
  • Content 网站的主体:首页时显示一条条的概要信息,内容页时显示文章具体内容
  • Side bar 侧边栏:显示介绍性的内容、推荐信息、广告等
  • Footer 页脚:显示 相关链接,主体信息(网站属于谁),备案信息(国内合规网站必备)等

直观表示,就是下图的样子:

添加图片注释,不超过 140 字(可选)

实际上,Wordpress 在设计之初,就是按照上面的页面结构来规划的。 页面上每一块内容,都被 Wordpress 划分成了一个个单独的文件,称之为模板文件,通过这些文件的组合显示完整的页面。

  • header.php 控制网页头部显示
  • sidebar.php 控制网页侧边栏显示
  • footer.php 控制网页底部显示
  • index.php 页面主要内容显示,不过要注意,index.php并不是严格意义上显示主体内容的,之后会对这个文件扩充解释

添加图片注释,不超过 140 字(可选)

这样最大的好处就是模块化,具体来说就是统一管理、统一配置、便于阅读、代码重用。

模板文件

header.php

网站头部信息,在大多数时候,是相对统一和固定的。

头部信息拆解到 header.php,代码类似下面:

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>模板文件</title>

<link rel="stylesheet" href="<?php bloginfo('stylesheet_url'); ?>" type="text/css" />

</head>

<body>

<div class="header-view">

<a class="logo" href="<?php home_url() ?>"><strong>Logo文字</strong></a>

<a class="menu" href="#">发现</a>

<a class="menu" href="#">关注</a>

<a class="menu" href="#">消息</a>

<input type="text" class="search" placeholder="搜索">

</div>

其他页面使用该头部信息的地方加上如下代码:

get_header();

获取到的就是 header.php文件中的完整内容,如果想修改页面上头部信息的显示方式,只用修改header.php文件即可。找起来容易,改起来方便。

sidebar.php

侧边栏的用途根据网站的定位显示内容千差万别,大部分wordpress主题网站显示文章的归档信息,广告栏(联盟广告、推荐内容,公众号二维码等等),CSDN 还显示了友情链接,备案信息等。

甚至还可以显示双侧 sidebar,中间显示内容,又比如 CSDN。当然,也有很多站点根本没有 sidebar。

Wordpress 默认实现了一个侧边栏,可以通过下面的代码来使用:

<aside id="secondary" class="sidebar widget-area" role="complementary">

<?php dynamic_sidebar( 'sidebar-1' ); ?>

</aside><!-- .sidebar .widget-area -->

将上述内容放置到 sidebar.php文件中,引用的地方加上如下代码:

<?php get_sidebar(); ?>

获取到的是 sidebar.php文件中完整内容。

footer.php

大部分网站会在网页最下方列出帮助信息,友情链接,版权信息,备案号等。

<div class="footer-view">

<a class="menu" href="#">关于我们</a>

<a class="menu" href="#">友情链接</a>

<a class="menu" href="#">内容合作</a>

</div>

<div class="footer-footer">

Copyright @ 2021 XXX 备案号000000

</div>

</body>

</html>

在需要引用到 footer.php的地方,加上如下代码:

<?php get_footer(); ?>

一般,只会在首页引用到 footer,而详情页大概率不会用到。

index.php

作为网站的主体内容,index.php在不同的场景下,扮演者不同的角色。

因此,往往在index.php中只有少量内容,而把主体内容交给 single.php 和 page.php 两个文件。

当网站位于首页时,使用index.php。首页指的是第一次进入站点,展示给用户的网页。 对于详情(内容)页,如果是静态内容,例如关于我们,特别说明等相对不会变化的内容,使用page.php,如果是正常发布的内容,就是网站中绝大多数内容都用single.php。

对于 index.php 中内容,可以参考下面的写法:

<?php

   get_header();

?>

<div class="content-area">

   <main id="main" class="site-main">

       <?php while (have_posts()) : the_post(); ?>

           <h1 class="article-title"><a href="<?php the_permalink() ?>"><?php the_title(); ?></a></h1>

           <article class="article-content">

               <?php the_excerpt(); ?>

           </article>

           <h5><?php the_author(); ?> &nbsp;&nbsp; <?php the_time('Y年n月j日') ?></h5>

       <?php  endwhile; ?>

   </main>

<?php get_sidebar(); ?>

</div>

<?php get_footer(); ?>

对于内容页 page.php,可以参考下面的写法:

<?php get_header(); ?>

<section class="container container-page">

<div class="content">

<?php while (have_posts()) : the_post(); ?>

<header class="article-header">

<h1 class="article-title"><a href="<?php the_permalink() ?>"><?php the_title(); ?></a></h1>

</header>

<article class="article-content">

<?php the_content(); ?>

</article>

<?php endwhile;  ?>

   </div>

   <?php get_sidebar(); ?>

</section>

<?php get_footer(); ?>

对于内容页 single.php,可以参考下面的写法:

<?php get_header(); ?>

<section class="container">

<div class="content-wrap">

<div class="content">

<?php while (have_posts()) : the_post(); ?>

<header class="article-header">

<h1 class="article-title"><a href="<?php the_permalink() ?>"><?php the_title(); ?></h1>

</header>

<?php tb_xzh_render_body() ?>

<article class="article-content">

<?php _the_ads($name='ads_post_01', $class='asb-post asb-post-01') ?>

<?php the_content(); ?>

</article>

</div>

</div>

<?php get_sidebar(); ?>

</section>

<?php get_footer();

仔细观察这些文件,发现它们的差别很小,甚至有时候,可以让 single.php 和 page.php一致。


相关文章
|
5月前
|
数据采集 存储 缓存
PHP爬虫的使用与开发
本文深入探讨了PHP爬虫的使用与开发,涵盖基本原理、关键技术、开发实践及优化策略。从发送HTTP请求、解析HTML到数据存储,再到处理反爬机制,全面指导读者构建高效可靠的爬虫程序。
134 3
|
2月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
166 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
25天前
|
关系型数据库 MySQL PHP
WordPress 开发入门:代码详解与使用指南
本文详细介绍了WordPress开发入门知识,涵盖基础概念、环境搭建、主题与插件开发及常用技巧。首先讲解了WordPress的核心功能与开发环境配置,接着深入探讨主题开发,包括创建主题文件夹、核心文件(style.css和functions.php)以及模板文件的使用。随后介绍插件开发的基本步骤,如创建插件文件、添加功能并激活插件。最后推荐了开发资源,如官方文档、在线教程和优质市场。通过实践与学习,读者可掌握WordPress开发技术,构建个性化网站。
|
1月前
|
API PHP 数据库
PhalApi 2.x:让PHP接口开发从“简单”到“极简”的开源框架
PhalApi 2.x 是一款专为接口开发设计的轻量级PHP框架,性能卓越且易于上手。它支持多协议、自动生成文档、提供多种客户端SDK,并采用现代化技术栈,适合中小型项目及微服务架构。通过清晰的分层架构和丰富的扩展库,开发者可快速构建高可用API。其日均超1000万次调用,广泛应用于移动App、物联网、电商等领域。官网:https://www.phalapi.net/,欢迎体验高效开发之旅!
ly~
|
8月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
182 6
|
8月前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性与扩展性本文旨在探讨PHP中常见的设计模式及其应用,帮助开发者编写出更加灵活、可维护和易于扩展的代码。通过深入浅出的解释和实例演示,我们将了解如何使用设计模式解决实际开发中的问题,并提升代码质量。
在软件开发过程中,设计模式是一套经过验证的解决方案模板,用于处理常见的软件设计问题。PHP作为流行的服务器端脚本语言,也有其特定的设计模式应用。本文将重点介绍几种PHP中常用的设计模式,包括单例模式、工厂模式和策略模式,并通过实际代码示例展示它们的具体用法。同时,我们还将讨论如何在实际项目中合理选择和应用这些设计模式,以提升代码的可维护性和扩展性。
140 4
|
6月前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
103 2
|
6月前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
7月前
|
SQL 关系型数据库 MySQL
PHP与MySQL协同工作的艺术:开发高效动态网站
在这个后端技术迅速迭代的时代,PHP和MySQL的组合仍然是创建动态网站和应用的主流选择之一。本文将带领读者深入理解PHP后端逻辑与MySQL数据库之间的协同工作方式,包括数据的检索、插入、更新和删除操作。文章将通过一系列实用的示例和最佳实践,揭示如何充分利用这两种技术的优势,构建高效、安全且易于维护的动态网站。
|
10月前
|
安全 IDE 编译器
深入理解PHP 7的新特性及其对现代Web开发的影响
【7月更文挑战第30天】本文将深入探索PHP 7版本中引入的关键新特性,并分析这些改进如何优化现代Web开发实践。通过对比PHP 5和PHP 7的性能差异,我们将揭示PHP 7如何提升应用响应速度和资源利用效率。此外,本文还将讨论PHP 7对开发者工作流程的影响,包括新的语言特性、错误处理机制以及内置函数的增强,旨在为读者提供全面了解PHP 7所带来的变革性影响。