综述和基本语法

  有4个文件加载语句:includerequireinclude_oncerequire_once

  • require函数通常放在 PHP 程序的最前面,PHP 程序在执行前,就会先读入 require 所指定引入的文件,使它变成 PHP 程序网页的一部份。
  • include函数一般放在流程控制的处理部分中。PHP程序网页在读到 include的文件时,才将它读进来。这种方式,可以把程序执行时的流程简单化。
  • include有返回值,而require没有
  • “require”的工作方式是为了让PHP程序得到更高的效率,当它在同一个PHP网页中解释过一次后,第二次出现便不会再解释,这是它的优点。不过严格来说,这也是它的唯一的缺点,因为它不会重复解释引入的文件,所以当PHP网页中使用循环或条件语句来引入文件时,“require”则不会做任何的改变。当有类似这样的情形时,就必须使用“include”命令来引入 文件了。
  • 当PHP遇到一个利用“include”方式引入的文件,它就会解释一次;遇到第二次时,PHP还是会重新解释一次。与“require”相比,“include”的执行效率则会下降许多;而且当引入文件中包含了用户自定义的函数时,PHP在解释的过程中会发生函数重复定义的问题。不过“include”也不是没有优点的,因为在PHP网页中,它会每遇到一次“include”命令就会重复解释一次,所以非常适合使用在循环或条件判断的语句里。
  • “include_once()”函数和“require_once()” 函数,会先检查目标档案的内容是不是在之前就已经导入过了,如果是,便不会再次重复导入同样的内容。
  • 他们可以载入 php 或 html 文件。

文件加载的路径问题

  前提说明:以下的说明举例,以 include 为例,也适用于其他3各加载语句。 
  有3种路径形式可以使用。

相对路径

  是相对于当前网页文件所在的位置来定位某个被加载的文件位置,主要依赖以下2个特殊符号: 
  . / :表示当前位置,即当前网页文件所在的目录(文件夹); 
  . . /:表示上一级位置,即当前网页文件所在目录的上一级目录; 
  用这2个符号来表达位置信息,比如:

include "./page1.php";     //表示当前网页文件所在文件夹的 page1.php 文件
include "../page2.php";
  • 1
  • 2

绝对路径

  绝对路径又分为本地绝对路径和网络绝对路径。

本地绝对路径

include "c:/d1/d2/p1.php";
  • 1

  特别注意:我们不应该在代码中直接写这种本地绝对路径!但,其实这种本地绝对路径的写法是很常用的! 
  那怎么做,实例如下: 
  

网络绝对路径

//实际这里载入的通常也都是 html文件,因为该服务器会将 php 文件执行后返回过来
include "http://www.abc123.com.index.php";
  • 1
  • 2

“无路径”(不推荐)

  形式就是没有给出路径信息,而只给出文件名,不推荐。 
  比如:

inclue "page1.php"; //此时通常其实php语言引擎会在当前网页目录下找该文件。
  • 1

关于路径问题详见:相对路径与绝对路径

文件载入和执行过程详解

  第一步:从 include 语句处退出 php 脚本模式(进入 html 代码模式) 
  第二步:载入 include 语句所设定的文件中的代码,并执行之(如同在当前文件中一样) 
  第三步:退出 html 模式,重新进入 php 脚本模式,继续之后的代码

4个载入语句的区别

include 和 require 的区别

  include 载入文件失败时(即没有找到该文件),报一个“提示错误”,然后继续执行后续代码; 
  require 载入文件失败时,报错并立即终止执行。 
  通常,require 用于在程序中,后续的代码依赖于载入的文件的时候。

include 和 include_once的区别

  include 载入的文件不判断是否重复,只要有 include 语句,就会载入一次——即此时可能导致重复载入。 
include_once 载入的文件会有内部判断机制“前面代码”是否已经载入过,就不再载入。

include_once 和 require_once 的区别

  同include和 require 的区别一样

require 和 require_once 的区别

  同 include 和 include_once 的区别一样

在被载入文件中 return 语句的作用

  include有返回值,而require没有 
   1.一个载入语句,如果载入成功,会有返回值,为1,如果载入失败,则返回的是 false(通常不使用该返回值)

  但,如果被载入文件中有 return 语句,此时就有另外的机制和作用: 
  2.return 语句此时的作用是终止载入过程——该 return 语句的后续代码(被载入文件中的)不再载入。

  3.return 语句也可用于该被载入文件载入时返回一个数据,形式为:return XX;

PHP文件引入的更多相关文章

  1. 关于echarts的使用----模块化单文件引入(推荐) 与标签式单文件引入

    官网:http://echarts.baidu.com/echarts2/doc/doc.html#引入ECharts3 关于模块化单文件引入(推荐) 与标签式单文件引入

  2. html文件引入其它html文件的几种方法:include方式

    可以在一个html的文件当中读取另一个html文件的内容吗?答案是确定的,而且方法不只一种,在以前我只会使用iframe来引用,后来发现了另外的几种方法,那今天就总结这几种方法让大家参考一下. 1.I ...

  3. vue脚手架使用swiper /引入js文件/引入css文件

    1.安装vue-cli 参考地址:https://github.com/vuejs/vue-cli 如果不使用严格语法需要在后三项打no:(加了挺头疼的,老是报错,但是对自己的代码规范性也是有很大的帮 ...

  4. 模板文件引入css样式文件

    引用路径问题:相对路径和绝对路径 相对路径:相对路口文件index.php设置 绝对路径:从虚拟主机站点目录开始设置 css样式文件引入图片,路径的设置 相对地址:相对css文件本身设置 ①模板文件 ...

  5. vue cli搭建项目及文件引入

    cli搭建方法:需安装nodejs先 1.npm install -g cnpm --registry=https://registry.npm.taobao.org //安装cnpm,用cnpm下载 ...

  6. flask 安装及基础学习(url_for反转,静态文件引入)

    pip3 install flask pycharm 创建项目 默认的代码解释说明(及开启debug模式) #encoding:utf-8 from flask import Flask #从flas ...

  7. CSS 文件引入

    CSS 文件引入 <html> <head> <!-- link标签引用其他文件.rel="stylesheet" 引用css.href=" ...

  8. JavaScript文件引入方式区别

    1.JavaScript文件引入方式 (1)正常引入 <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js&quo ...

  9. 【TP3.2】模板布局和文件引入

    TP3.2框架引入文件使用<include file="blue/common/header">标签,==>blue主题下的公共头文件(blue放在View/目录 ...

  10. echarts学习心得1---模块化单文件引入和标签式单文件引入

    一.模块化单文件引入 1. 为ECharts准备一个具备大小(宽高)的Dom(当然可以是动态生成的) <div id="main" style="height:40 ...

随机推荐

  1. SE Springer小组《Spring音乐播放器》可行性研究报告一、二

    1 引言 1.1编写目的 <软件工程>课程,我们团队计划开发一个音乐播放器.本文档是基于网络上现有的音乐播放器的特点,团队计划实现的音乐播放器功能和团队人员的综合实力等情况,说明该软件开发 ...

  2. 初识asp

    1.ASP(Active Server Pages 动态服务器页面)是一种生成动态交互性网页的强有力工具 <!DOCTYPE html> <html> <body> ...

  3. 5G时代

    电信语音承载在CDMA2G网络--所以2G基本没有网络 网络走fdd4g 如果5G时代来临,4g网络可能就会像3G一样的慢

  4. 【第十周】psp

    代码累计 300+575+475+353+620+703=2926 随笔字数 1700+3000+3785+4210+4333+3032=20727 知识点 机器学习,支持向量机 数据库技术 Acm刷 ...

  5. HDU 2061 Treasure the new start, freshmen!

    http://acm.hdu.edu.cn/showproblem.php?pid=2061 Problem Description background:A new semester comes , ...

  6. vue中的数据双向绑定

    学习的过程是漫长的,只有坚持不懈才能到达到自己的目标. 1.vue中数据的双向绑定采用的时候,数据劫持的模式.其实主要是用了Es5中的Object.defineProperty;来劫持每个属性的get ...

  7. ERROR 1698 (28000): Access denied for user 'root'@'localhost' 解决方法

    之前MySQL服务端本机上使用密码登陆root账号是没有问题的,但是今天不知道是因为动了哪里,登陆失败并有这个错误代码: ~$ mysql -u root -p Enter password: ERR ...

  8. multi thread for Java

    I try to do a testing for HashTable Sychronized behavior today. As an Sychronized Object, HashTable ...

  9. Python面向对象高级编程:__slot__(给实例添加方法、属性)

    纲要: 本章总的来说是给实例添加属性,给类添加方法两个主题,以及相应的作用范围.总结如下: 1.给实例添加属性(作用范围:当然是只对当前实例有效): 2.用__slots__限制可以给实例添加的属性( ...

  10. P2303 [SDOi2012]Longge的问题

    题目描述 Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). 输入输出格式 输入格式: 一 ...