
本文旨在解决使用PHP `include`功能构建网页时,页脚与主体内容重叠的问题。核心在于纠正不规范的HTML结构,确保每个页面只有一个`html>`和`
`标签,并合理组织导航、内容和页脚的php包含文件,同时优化脚本加载位置和元素间距,以实现稳固且响应式的页面布局。
理解问题根源:不规范的html结构
在使用PHP的include或require语句构建模块化网页时,一个常见的问题是由于不正确的HTML结构导致页脚与主体内容重叠。这通常发生在多个被包含的文件(如导航栏和页脚)各自包含了完整的、
或标签时。当这些文件被主页面引入时,最终渲染的HTML文档将包含重复的这些标签,从而破坏了文档流,特别是当内容区域高度动态变化时,固定定位或不当的css布局会导致页脚被内容覆盖。
例如,原始代码中 navigation.php 文件包含了完整的和
标签,而 registration.php 也再次包含了这些标签。这导致了最终页面中存在多个标签,浏览器解析时可能会产生不可预测的布局行为。
解决方案:构建单一且规范的HTML文档结构
解决此问题的关键是确保最终渲染的HTML文档只包含一个、一个
和一个标签。这意味着,通过PHP include引入的组件文件(如导航、页脚)不应包含这些顶级标签,而应只包含它们各自的功能性HTML片段。
立即学习“PHP免费学习笔记(深入)”;
1. 优化主页面(registration.php)结构
主页面应该作为整个HTML文档的入口,负责定义唯一的、
和标签,并按逻辑顺序包含其他组件。
主要改进点:
- 定义标准的html5文档结构。
- 在中统一引入所有CSS文件(如bootstrap)。
- 在的起始位置包含导航栏。
- 在的末尾,内容之后,包含页脚。
- 将所有javaScript脚本放在标签的结束之前,以提高页面加载性能。
示例代码:registration.php
<!DOCTYPE html> <html lang="en"> <head> <title>SMS</title> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <!-- 统一引入Bootstrap CSS --> <link href="bootstrapfile/bootstrap.min.css" rel="stylesheet"> <!-- 其他可能需要的CSS文件 --> </head> <body> <?php include "navigation.php"; // 引入导航栏 ?> <section class="vh-100"> <!-- 注意:vh-100可能会导致内容溢出时页脚被推到底部,若内容高度不足视口,页脚可能不会紧贴底部。根据实际需求调整。 --> <div class="container h-100"> <div class="row d-flex justify-content-center align-items-center h-100"> <div class="col-lg-12 col-xl-11"> <div class="card text-black" style="border-radius: 50px;"> <div class="card-body p-md-5"> <div class="row justify-content-center"> <div class="col-md-10 col-lg-6 col-xl-5 order-2 order-lg-1"> <p class="text-center h1 fw-bold mb-5 mx-1 mx-md-4 mt-4">Sign up</p> <form class="mx-1 mx-md-4"> <!-- 表单内容保持不变 --> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-user fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="text" id="form3Example1c" class="form-control" /> <label class="form-label" for="form3Example1c">Your Name</label> </div> </div> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-envelope fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="email" id="form3Example3c" class="form-control" /> <label class="form-label" for="form3Example3c">Your Email</label> </div> </div> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-lock fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="password" id="form3Example4c" class="form-control" /> <label class="form-label" for="form3Example4c">Password</label> </div> </div> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-key fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="password" id="form3Example4cd" class="form-control" /> <label class="form-label" for="form3Example4cd">Repeat your password</label> </div> </div> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-key fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="password" id="form3Example4cd" class="form-control" /> <label class="form-label" for="form3Example4cd">Date of Birth</label> </div> </div> <div class="d-flex flex-row align-items-center mb-4"> <i class="fas fa-key fa-lg me-3 fa-fw"></i> <div class="form-outline flex-fill mb-0"> <input type="password" id="form3Example4cd" class="form-control" /> <label class="form-label" for="form3Example4cd">Date of Join</label> </div> </div> <div class="d-flex justify-content-center mx-4 mb-3 mb-lg-4"> <button type="button" class="btn btn-primary btn-lg">Register</button> </div> <div class="form-check d-flex justify-content-center mb-5"> <label class="form-check-label" for="form2Example3"> <a style="text-decoration: none" class="text-danger" href="studentLogin.php">Back to Login Page</a> </label> </div> </form> </div> <div class="col-md-10 col-lg-6 col-xl-7 d-flex align-items-center order-1 order-lg-2"> @@##@@ </div> </div> </div> </div> </div> </div> </div> </section> <?php include "footer.php"; // 引入页脚 ?> <!-- 统一引入所有javascript脚本,通常放在body结束标签前 --> <script src="bootstrapfile/bootstrap.bundle.min.js"></script> <!-- 其他可能需要的JS文件 --> </body> </html>
2. 优化导航栏(navigation.php)结构
navigation.php 文件应只包含导航栏的HTML代码,不包含任何、
或标签。
主要改进点:
- 移除、、标签及其对应的结束标签。
- 使用Bootstrap的边距类(如mb-2)代替
标签来创建元素间的垂直间距,这提供了更好的控制和响应性。
示例代码:navigation.php
<nav class="navbar navbar-expand-sm bg-info navbar-light mb-2"> <a class="navbar-brand" href="#">SMS</a> <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#mango"> <span class="navbar-toggler-icon"></span> </button> <div class="collapse navbar-collapse" id="mango"> <ul class="navbar-nav"> <!-- 移除重复的id="mango" --> <li class="nav-item"> <a class="nav-link" href="">Home</a> </li> <li class="nav-item"> <a class="nav-link" href="">About us</a> </li> <li class="nav-item"> <a class="nav-link" href="">About us</a> </li> <li class="nav-item dropdown"> <a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#">Login Panel</a> <ul class="dropdown-menu"> <li><a class="dropdown-item" href="studentLogin.php">Student Login</a></li> <li><a class="dropdown-item" href="#">Teacher Login</a></li> </ul> </li> </ul> </div> </nav>
3. 优化页脚(footer.php)结构
footer.php 文件应只包含页脚的HTML代码。JavaScript脚本不应放在这里,而应统一在主页面的
结束标签前引入。
主要改进点:
- 移除、、标签及其对应的结束标签。
- 移除<script>标签,将其移至主页面。</script>
示例代码:footer.php
<!-- Footer --> <footer class="text-center text-lg-start bg-info text-muted"> <!-- Section: Social media --> <section class="d-flex justify-content-center justify-content-lg-between p-4 border-bottom"> </section> <!-- Section: Social media --> <!-- Section: Links --> <section class=""> <div class="container text-center text-md-start mt-5"> <!-- Grid row --> <div class="row mt-3"> <!-- Grid column --> <div class="col-md-3 col-lg-4 col-xl-3 mx-auto mb-4"> <!-- Content --> <h6 class="text-uppercase fw-bold mb-4"> <i class="fas fa-gem me-3"></i>Company name </h6> <p> Here you can use rows and columns to organize your footer content. Lorem ipsum dolor sit amet, consectetur adipisicing elit. </p> </div> <!-- Grid column --> <!-- Grid column --> <div class="col-md-2 col-lg-2 col-xl-2 mx-auto mb-4"> <!-- Links --> <h6 class="text-uppercase fw-bold mb-4"> Products </h6> <p> <a href="#!" class="text-reset">Angular</a> </p> <p> <a href="#!" class="text-reset">react</a> </p> <p> <a href="#!" class="text-reset">vue</a> </p> <p> <a href="#!" class="text-reset">laravel</a> </p> </div> <!-- Grid column --> <!-- Grid column --> <div class="col-md-3 col-lg-2 col-xl-2 mx-auto mb-4"> <!-- Links --> <h6 class="text-uppercase fw-bold mb-4"> Useful links </h6> <p> <a href="#!" class="text-reset">Pricing</a> </p> <p> <a href="#!" class="text-reset">Settings</a> </p> <p> <a href="#!" class="text-reset">Orders</a> </p> <p> <a href="#!" class="text-reset">Help</a> </p> </div> <!-- Grid column --> <!-- Grid column --> <div class="col-md-4 col-lg-3 col-xl-3 mx-auto mb-md-0 mb-4"> <!-- Links --> <h6 class="text-uppercase fw-bold mb-4">Contact</h6> <p><i class="fas fa-home me-3"></i> New York, NY 10012, US</p> <p> <i class="fas fa-envelope me-3"></i> <a class="__cf_email__" data-cfemail="e881868e87a88d90898598848dc68b8785" href="/cdn-cgi/l/email-protection">[email protected]</a> </p> <p><i class="fas fa-phone me-3"></i> + 01 234 567 88</p> <p><i class="fas fa-print me-3"></i> + 01 234 567 89</p> </div> <!-- Grid column --> </div> <!-- Grid row --> </div> </section> <!-- Section: Links --> <!-- Copyright --> <div class="text-center p-4" style="background-color: rgba(0, 0, 0, 0.05);"> © 2021 Copyright: <a class="text-reset fw-bold" href="https://mdbootstrap.com/">MDBootstrap.com</a> </div> <!-- Copyright --> </footer> <!-- Footer -->
注意事项与最佳实践
- 单一HTML结构原则: 始终确保最终渲染的HTML页面只包含一个、和标签。所有通过PHP include引入的组件文件都应该是HTML片段,而不是完整的HTML文档。
- 脚本加载位置: 将所有JavaScript文件(包括Bootstrap的JS bundle)放在标签的结束之前。这有助于提高页面加载速度,因为浏览器可以先渲染页面内容,再执行脚本。
- 使用Bootstrap工具类: 优先使用Bootstrap提供的工具类(如mb-2用于margin-bottom)来控制元素间距,而不是使用
标签。Bootstrap的工具类提供了更好的语义化、响应式支持和一致性。 - 避免vh-100的滥用: 在内容区域使用vh-100(视口高度100%)时需谨慎。如果内容高度不足以填满整个视口,页脚可能会被“吸附”到视口底部,而不是紧跟在内容之后。如果内容溢出,vh-100可能导致滚动条出现。对于动态内容,通常更好的做法是让内容区域自然地根据其内部元素的高度进行扩展。如果需要“粘性页脚”,可以考虑使用CSS Flexbox或Grid布局来实现。
- 代码复用与维护: 遵循上述结构,可以大大提高代码的复用性和可维护性。当需要修改导航栏或页脚时,只需修改对应的PHP文件即可,而无需触及每个页面。
通过遵循这些最佳实践,您将能够构建出结构清晰、布局稳定且易于维护的PHP网站,有效解决页脚重叠等常见的布局问题。
