pHp静态页面教程(模板及模板解析)(组图)

2023-12-03    分类: 网站建设

1、server会依据文件的后缀名去进行解析,假设是HTML文件则server不会进行语法解析。而是直接输出到浏览器。
2、假设一个页面中所有都是HTML代码而没有须要解析的pHp语法,则没有必要保存为pHp文件,这样反而会减少执行效率。

3、假设是须要pHp控制HTML代码的输出,比方须要pHp推断用户是否登陆,假设登陆则输出A,未登录则输出b。这就须要pHp来进行控制了。HTML不能实现这种功能

pHp生成静态页面教程,一些主要概念

一,pHp 脚本和动态页面。

pHp 脚本是一个结束脚本程序,可以通过嵌入等方式与 HTML 文件混合。也可以归类。功能包装等形式。以模板的形式处理用户请求。

无论如何,它的基本原理是这样的。通过发出请求,请求某个页面----->引入指定的对应脚本进行处理----->脚本被加载----->脚本被指定的pHp解析器解析形成HTML语言形式- --->解析后的HTML语句以包的形式发回浏览器。

不难看出,页面发送到浏览器后,pHp 就不复存在了。已转换并解析为 HTML 语句。客户端请求是一个动态文件。事实上php代码怎么放到html,那里不存在真正的文件。由pHp解析形成相应的页面,然后发送回浏览器。

这种页面处理方式称为“动态页面”。

两个。静态页面。

静态页面是指只包含最后确实存在的HTML、JS、CSS等执行脚本的页面。

它的处理方式是。按要求。请求页面 ----> 确认并加载页面 ----> 将页面以包的形式传回浏览器。

从这个过程,我们来对比一下动态页面。你现在可以。动态页面需要通过pHp解析器进行解析,通常需要连接数据库进行数据库访问操作。然后就可以形成HTML语言信息包。静态页面不需要解析或连接数据库直接发送,可以大大降低压力,提高负载能力。显着提供页面打开速度和网站整体打开速度。但它的缺点是不能动态处理请求,而且文件必须实际存在于其上。

三个。模板和模板分析。模板尚未填充内容 html 文件。例如:

temp.html

代码:

 
星空体育app最新版本(2024已更新)


 
 
this is a { file } file's templets 





 
 
pHp处理: 
 templetest.php 
Code:   >

模板解析处理是将pHp脚本解析处理后得到的结果填充()到模板中的过程。通常在模板类的帮助下。目前比较流行的模板解析类是。还有很多。模板分析处理的原则通常是替换。一些程序员习惯于将推理、循环和其他处理放入模板文件中。使用解析类来处理,典型的应用是一个概念,简单来说就是一个循环处理。

pHp 脚本指定循环次数、如何循环替换等,然后模板解析类详细实现这些操作。

好吧,我已经比较了静态和动态页面的优缺点。现在让我们谈谈它。如何用pHp生成静态文件。

pHp 生成静态页面,不代表 pHp 的动态分析和 HTML 页面的输出。它是指用 pHp 创建 HTML 页面。

同时,由于HTML的不可写性,如果我们创建的HTML发生变化,我们需要将其删除并重新生成。 (当然你也可以选择使用正则进行修改,但个人觉得还是删掉重新生成比较好。有些得不偿失。)

回到正题。用过pHp文件操作函数的pHp爱好者都知道。 pHp 中有一个文件操作函数。文件被打开。如果文件不存在,请尝试创建。

这是pHp可以用来创建HTML文件的理论基础。只有用来存放HTML文件的文件夹才有写权限(即权限定义0777)。可以创建文件。(对于UNIX系统,Win系统不需要考虑。)以上面的例子为例,如果我们修改最后一句,指定在test文件夹下生成一个名为test.html的静态文件:

代码:

php 
$title = "拓迈国际測试模板"; 
$file = "TwoMax Inter test templet, 
author:Matrix@Two_Max"; 
 $fp = fopen ("temp.html","r"); 
$content = fread ($fp,filesize ("temp.html")); 
$content .= str_replace ("{ file }",$file,$content); 
$content .= str_replace ("{ title }",$title,$content); 
// echo $content; 
$filename = "test/test.html"; 
$handle = fopen ($filename,"w"); //打开文件指针。创建文件 
/* 
 检查文件是否被创建且可写 
*/ 
if (!is_writable ($filename)){ 
die ("文件:".$filename."不可写。请检查其属性后重试。"); 
} 
if (!fwrite ($handle,$content)){ //将信息写入文件 
die ("生成文件".$filename."失败!"); 
} 
fclose ($handle); //关闭指针 
die ("创建文件".$filename."成功!

"); ?>

实际应用中常见问题解决方法参考: 1.文章列表问题:在数据库中创建一个字段。记录文件名,每次生成文件时将自己自动生成的文件名存入数据库。对于推荐文章,只需指向指定静态文件存放目录下的页面即可。使用pHp操作处理文章列表,保存为字符串,生成页面时替换此字符串。

例如在页面上放置文章列表的表格中添加标签{},在pHp处理文件中:

代码:

"); 
} 
if (!fwrite ($handle,$content)){ //将信息写入文件 
die ("生成文件".$filename."失败!

"); } fclose ($handle); //关闭指针 die ("创建文件".$filename."成功。"); ?>

其次,分页问题。例如,当我们指定分页时,每页有 20 篇文章。某个子频道的列表中的文章数已经被数据库查询到了45。但是。首先我们通过查询得到如下参数: 1.总页数; 2、每页文章数。

第二步,for ($i = 0; $i

";把这句话去掉php代码怎么放到html,放在循环后的显示器上,因为这句话会停止程序运行。例:

代码:

$fp = fopen ("temp.html","r"); 
$content = fread ($fp,filesize ("temp.html")); 
$onepage = '20'; 
$sql = "select id from article where channel='$channelid'"; 
$query = mysql_query ($sql); 
$num = mysql_num_rows ($query); 
$allpages = ceil ($num / $onepage); 
for ($i = 0;$i<$allpages; $i++){ 
if ($i == 0){ 
$indexpath = "index.html"; 
} else { 
$indexpath = "index_".$i."html"; 
} 
$start = $i * $onepage; 
$list = ''; 
$sql_for_page = "select name,filename,title from article where channel='$channelid' limit $start,$onepage"; 
$query_for_page = mysql_query ($sql_for_page); 
while ($result = $query_for_page){ 
$list .= ''.$title.''; 
} 
$content = str_replace ("{ articletable }",$list,$content); 
if (is_file ($indexpath)){ 
@unlink ($indexpath); //若文件已存在。则删除 
} 
$handle = fopen ($indexpath,"w"); //打开文件指针。创建文件 
/* 
  检查文件是否被创建且可写 
*/ 
if (!is_writable ($indexpath)){ 
echo "文件:".$indexpath."不可写,请检查其属性后重试!

"; //改动为echo } if (!fwrite ($handle,$content)){ //将信息写入文件 echo "生成文件".$indexpath."失败!"; //改动为echo } fclose ($handle); //关闭指针 } fclose ($fp); die ("生成分页文件完毕。如生成不全然,请检查文件权限系统后又一次生成!

"); ?

>

总体思路是这样的。其中,其他数据生成、数据输入输出检查、页面内容指向等可酌情添加到页面中。

在实际文章系统处理过程中。还有很多问题需要考虑。与动态页面不同,还有很多需要注意的地方。

但总体思路是一样的。其他方面可以相互推论。

使用pHp制作静态网站模板框架

模板可以改善网站的结构。

本文解释了如何在 pHp 4 中传递一个新的特性和模板类。在一个由大量静态 HTML 页面组成的站点中,您可以巧妙地使用模板来控制页面布局。

大纲:

==================================

独立的功能和布局

避免重复的页面元素

静态网站的模板框架

==================================

单独的功能和布局首先我们来看一下应用模板的两个主要目的:

分离功能(pHp)和布局(HTML)以避免页面元素重复

第一个目的是谈论最多的目的。它设想了这样一种情况,一群程序员编写pHp脚本来生成页面内容,同时还有一群设计者设计HTML和图形来控制页面。外部的。功能和布局分离的基本思路是让这两组人能够编写和使用一组独立的文件:程序员只需要关心那些只包含pHp代码的文件,不需要关心页面外观

。并且页面设计者可以使用他们最熟悉的可视化编辑器来设计页面布局。无需担心破坏页面中嵌入的任何 pHp 代码。

假设你之前看过一些关于pHp模板的教程,那么你应该已经明确了模板的工作机制。考虑一个简单的页面部分:页面顶部是页眉。左边是导航栏,其余是内容区。这样的站点可以有如下模板文件:

 
 
星空体育app最新版本(2024已更新)



 
 
{HEADER}
{LEFTNAV}{CONTENT}

条形

您可以看到页面是如何从这些模板构建的:主模板控制整个页面的布局。模板和模板控制页面的公共元素。花括号“{}”内的标识符是内容占位符。使用模板最基本的好处是界面设计者可以根据自己的意愿编辑这些文件,比如设置字体、改变颜色和图形,或者完全改变页面的布局。

界面设计师可以使用任何普通的 HTML 编辑器或可视化工具编辑这些页面。因为这些文件只包含 HTML 代码。无论什么 pHp 代码。

所有的 pHp 代码都保存在一个单独的文件中。这个文件就是页面 URL 实际调用的文件。文件由pHp引擎解析,结果返回给浏览器。

一般。 pHp 代码始终动态生成页面内容,例如查询数据库或运行某些计算。下面是一个例子:

define( array( 'main' => 'main.htm', 
'header' => 'header.htm', 
'leftnav' => 'leftnav.htm' ) ); 
// 此处的pHp代码设置$content使其包括合适的页面内容 
$tpl->assign('CONTENT', $content); 
$tpl->parse('HEADER', 'header'); 
$tpl->parse('LEFTNAV', 'leftnav'); 
$tpl->parse('MAIN', 'main'); 
$tpl->Fastprint('MAIN'); 
?

>

这里我们使用流行的模板类。但是对于许多其他模板类,基本思想是相同的。

首先实例化一个类,告诉它在哪里可以找到模板文件以及哪个模板文件对应于页面的哪个部分。下一步是生成页面内容。将结果分配给内容的标识符;然后,依次解析每个模板文件,模板类将执行必要的替换操作。最后将分析结果输出到浏览器。

该文件完全由 pHp 代码组成。不包含任何 HTML 代码。这是它大的优势。

如今,pHp 程序员可以专注于编写生成页面内容的代码。您不必担心如何生成 HTML 以正确设置最终页面的格式。

您可以使用此方法和上述文件来构建一个完整的站点。假设 pHp 代码根据 URL 中的查询字符串生成页面内容。例如。您可以相应地构建一个完整的杂志站点。

很容易看出使用模板还有第二个优势。

如上例所示。页面左侧的导航栏单独保存为文件。我们只需要编辑这个模板文件就可以改变网站所有页面左侧的导航栏。

避免重复的页面元素

“这真是太好了”,您可能会想,“我的网站主要由大量静态页面组成。

现在我可以从所有页面中删除他们的公共部分。更新这些公共部分太麻烦了。

将来,我将能够使用模板来创建非常易于维护的统一页面布局。 “但事情并没有那么简单。”大量静态页面说明问题。

请考虑上面的例子。这个示例实际上只有一个 .php 页面。之所以能生成整个站点的所有页面,是因为它利用URL中的查询字符串,从数据库等信息源动态构建页面。

我们大多数人运行的网站不一定有数据库支持。

我们的网站大部分都是由静态页面组成的,然后我们使用pHp在这里和那里添加了一些动态功能,例如搜索引擎、反馈表单等。

那么,如何在这样的网站上应用模板?

最简单的方法是为每个页面复制一个pHp文件,

然后将表示 pHp 代码中内容的变量设置为每个页面中相应的页面内容。

比如有三个页面,分别是首页(home)、关于()和产品()。我们可以从三个文件中分别生成它们。这三个文件的内容都类似于:

define( array( 'main' => 'main.htm', 
'header' => 'header.htm', 
'leftnav' => 'leftnav.htm' ) ); 
$content = "

欢迎訪问

希望你可以喜欢本站点

"; $tpl->assign('CONTENT', $content); $tpl->parse('HEADER', 'header'); $tpl->parse('LEFTNAV', 'leftnav'); $tpl->parse('MAIN', 'main'); $tpl->Fastprint('MAIN'); ?>

显然。这种方式存在三个问题:我们要复制这些复杂的pHp代码,涉及每个页面的模板,这使得页面像重复的公共页面元素一样难以维护;现在这些文件与 HTML 和 pHp 代码混合在一起。给内容变量赋值会变得非常困难,因为我们要处理大量的特殊字符。

解决问题的关键是将pHp代码和HTML内容分开,虽然我们无法从文件中删除所有HTML内容。但它可以删除大部分 pHp 代码。

静态网站模板框架

首先,我们像之前一样为页面的所有常用元素和页面的整体布局编写模板文件;然后删除所有页面的公共部分,只留下页面内容。接下来,向每个页面添加三行 pHp 代码,如下所示:

php require('prepend.php'); ?> 
 

你好

欢迎訪问

希望你可以喜欢本站点

?

>

这种方法基本上克服了上面提到的各种问题。今天文件中只有三行pHp代码,没有一行代码直接引用模板。因此,修改这些代码的可能性极小。另外,因为 HTML 内容在 pHp 标签之外。因此,不存在处理特殊字符的问题。我们可以轻松地将这三行 pHp 代码添加到所有静态 HTML 页面中。

该函数引入了一个 pHp 文件。此文件包含与模板相关的所有必要 pHp 代码。

该函数设置模板对象和页面标题。该函数解析模板并生成结果并发送给浏览器。

这是如何实现的?为什么在调用函数之前文件中的HTML没有发送到浏览器?答案在于 pHp 4 的一个新特性,它同意将输出到浏览器的内容拦截到缓冲区中。

我们来看看.php的详细代码:

define( array( 'main' => 'main.htm', 
'header' => 'header.htm', 
'leftnav'=> 'leftnav.htm' ) ); 
$tpl->assign('TITLE', $title); 
ob_start(); 
} 
function pageFinish() { 
GLObAL $tpl; 
$content = ob_get_contents(); 
ob_end_clean(); 
$tpl->assign('CONTENT', $content); 
$tpl->parse('HEADER', 'header'); 
$tpl->parse('LEFTNAV', 'leftnav'); 
$tpl->parse('MAIN', 'main'); 
$tpl->Fastprint('MAIN'); 
} 
?> 

该函数首先创建并设置一个模板实例。然后启用输出缓存。

在那之后。页面本身的所有 HTML 内容都将进入缓存。该函数获取缓存中的内容。然后在模板对象中指定这些内容。最后解析模板并输出完成的页面。

这就是整个模板框架的全部工作过程。

先写一个模板,包含网站每个页面的公共元素,然后把所有页面的公共页面布局代码全部删除,替换成三行永远不需要修改的pHp代码;然后添加类文件和 .php 以包含 path,这样您就可以得到一个可以集中控制页面布局的站点。它具有更好的可靠性和可维护性。并且站点级别的大规模修改变得非常容易。

本文下载包包含

一个可执行的演示站点,它的代码凝视比以前的代码凝视更具体。该类可以在。最新版本是1.1.0,还有一个小补丁用来保证这个类在pHp 4中正确执行。本文下载代码中的类已经被这个补丁修正了。

pHp轻松生成静态页面

 
 
 
 
星空体育app最新版本(2024已更新)


 

 
 

while($re = mysql_fetch_array($result)){ ?>

} ?

>

标题 公布时间
">

>

= $re["datetime"]?>

加入新闻

>

用pHp生成静态网页的两个函数

近年来。万维网(也称为万维网。WWW)正在不断地改变着信息处理技术的面貌。网络已成为高速的有效介质。并且适合人与企业之间的交流与协作。几乎所有的信息技术领域都普遍受到WEb的影响。 Web 访问带来了许多其他用户和许多其他数据。这意味着数据库面临很多其他压力,最终用户的响应速度越来越慢。与不断增加 CpU、磁盘驱动器和内存以跟上这种增长的需求相比,静态网页应该更有用。更经济的选择。

静态WEb动态网页用pHp的详细实现功能见()

function gen_static_file($program, $filename) 
{ 
$program 1= "/usr/local/apache/htdocs/php/" . $program; 
$filename1 = "/usr/local/apache/htdocs/ static_html/" . $filename; 
$cmd_str = "/usr/local/php4/bin/php " . $program1 . " } " . $filename1 . " "; 
system($cmd_str); 
echo $filename . " generated.〈br〉"; 
} 

这个函数是实现静态的关键,即pHp动态页面程序不是发送到浏览器,而是输入到名为$的文件中(如2)所示。

这两个参数中,$是pHp动态页面程序,$是生成的静态页面的名称(可以根据自己的需要制定自己的命名规则,这个很重要,见下文),/usr/ /php4/bin/php 是pHp中具有将程序输入文件功能的部分。它是一个在 pHp 中运行外部命令的函数。我们还可以看到,所有生成动态页面的php程序都需要放在/php/文件夹中,所有新生成的静态页面都会出现在//文件夹中(这些路径可以根据具体需求设置)。

让我们在下面给出一个详细的例子。看看静态的.php页面是如何生成的。

function gen_college_static () 
{ 
for ($i = 0; $i 〈= 32; $i++〉 
{ 
putenv("province_id=" . $i); //*.php文件从数据库取数据时要用到。 
$filename = " college_static". $i . ".html"; 
gen_static_file("college_static.php", $filename); 
} 

从这个函数可以看出,通过调用函数(),.php是静态的。变成了33个静态页面..html~..html,其中$会随着$I的变化而变化。当然,也可以直接从数据库中取值。为了控制生成的静态页面的数量和名称,其他程序对生成的静态页面的调用应与静态页面的命名规则保持一致。

分享题目:pHp静态页面教程(模板及模板解析)(组图)
网页路径:/news34/298534.html

成都网站建设公司_创新互联,为您提供Google网站策划小程序开发服务器托管App开发网站制作

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

搜索引擎优化