<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html ns="http://www.w3.org/1999/xhtml"><head>< http-equiv="Content-Type" content="text/html; charset=utf-8" />< >demo</ ></head><body> <p style="color: #ff9000;">%demo%</p></body></html>
这是需要替换的页面
PHP页面的静态化很有必要,尤其是在CMS系统中,一些内容一旦生成,基本上不会有变化,这时如果用html将页面静态化,无疑会减少服务其解析PHP页面的负担。以下是看书学来的PHP静态化技术,记录之以备不时之需。
无论是利用框架还是简单的脚本,原理基本一致:就是利用PHP进行文件操作,替换html模板中的动态元素,不仅能提高用户的访问速度还能让php与html分离,使代码更具有维护性。
用到的文件操作函数:
fopen() -------------------- 打开一个文件 函数有两个参数: 1.打开文件的路径和文件名 2.打开文件所用的模式(字符串形式) 这里用到了r 和 w r代表只读 w代表只写
feof() -------------------- 读取文件直到文件末尾 这个函数会在读取到文件的末尾返回true 那么就可以用while知道何时读完文件;函数有一个参数,1.打开的文件指针
fwiter() -------------------- 写入文件内容,函数有三个参数:1.写入的文件名称 2.写入的内容 3.(可选) 写入的最大字符数
fclose() ------------------------ 关闭文件;一般做完所有操作后必须关闭文件;
注意事项: 需要注意文件的路径;以及读取文件所需要的权限 ;
php代码:
<?phpheader("Content-type:text/html,charset=utf-8");/******php静态化*******/ class textHtml{ public function fwriteHtml($r){ /*php页面静态化技术 *$r [array]; *route=>生成文件名称及路径 *html=>需要读取的静态资源 *stsyem=>要替换的标签 *content=>标签替换的内容 * */ $cfill = fopen($r["html"],"r");//读取的文件名 $cfillnew = fopen($r["route"],"w"); while(!feof($cfill)){ $row = fgets($cfill);
$res = str_replace($r["stsyem"],$r["content"],$row); //替换内容
fwrite($cfillnew,$res);//写入html文件 } /*关闭文件*/ fclose($cfill); fclose($cfillnew); } } $f = new textHtml; $fillname = microtime().".html"; $content = "这是一个页面静态化技术"; $r["route"] = $fillname; $r["html"] = "index.html"; $r["stsyem"] = "%demo%"; $r["content"] = $content; $f->fwriteHtml($r);?>
最后得到的结果:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html ns="http://www.w3.org/1999/xhtml"><head>< http-equiv="Content-Type" content="text/html; charset=utf-8" />< >全国城市三级联动</ ></head><body> <p style="color: #ff9000;">这是一个页面静态化技术</p></body></html>
利用php静态化技术可以更好的实现网页功能 ; 在创建文章或者一些不经常改变内容中都可以用到;
========================================================转载请注明出处。
继续阅读与本文标签相同的文章
-
前端开发:面向对象与javascript中的面向对象实现(一)
2026-06-02栏目: 教程
-
怎么样才能有效的学习?
2026-06-02栏目: 教程
-
前端开发:css技巧,如何设置select、radio 、 checkbox 、file这些不可直接设置的样式 。
2026-06-02栏目: 教程
-
前端开发:css基础知识之盒模型以及浮动布局。
2026-06-02栏目: 教程
-
前端开发:Javascript中的数组,常用方法解析
2026-06-02栏目: 教程
