PHP/HTML混写的四种方式总结


Posted in PHP onFebruary 27, 2017

PHP作为一款后端语言,为了输出给浏览器让浏览器呈现出来,无可避免的要输出HTML代码,下文介绍下我用过的三种PHP/HTML混编方法

1、单/双引号包围法

这是最初级的方法了,用法就像下面这样

<?php
 echo '
 <!DOCTYPE html>
 <html>
   <head>
     <title> </title>
   </head>
   <body>
     <span>测试页面</span>
   </body>
 </html>
 ';
?>

这样是最简单的一种方法了,直接用单引号包装上就行了

至于双引号和单引号的区别,就在于前者解析引号内的变量,而后者不解析引号内的变量,参看下面的例子

<?php
 $Content='Hello!';
 echo "$Content";
 echo '<br>';
 echo '$Content';
 ?>

输出

1 Hello!
2 $Content

由此可见,用双引号包围的字符串中的变量名自动解析为了变量值,而用单引号包围则依然显示变量名

这样书写的缺点有两点

1、如果输出内容中包含单/双引号将极难处理,因为PHP无法判断这个引号是属于程序的还是输出内容的,所以会报错

2、这样书写一些现代文本编辑器(如SublimeText)将无法对引号包围的输出的内容进行语法着色,如果出现一些格式问题将极难发现。图中为SublimeText3的一张截图,上面的是正常的着色,下面则是用引号包围的着色

PHP/HTML混写的四种方式总结

2、使用HEREDOC/NOWDOC

HEREDOC和NOWDOC是PHP5.3开始支持的一种新特性,它允许在程序中使用一种自定义的标志符来包围文本,而HEREDOC和NOWDOC的关系就类似于双引号包围和单引号包围一样,前者解析区块内的变量,而后者不解析区块内的变量

下面介绍HEREDOC和NOWDOC的用法

<?php
 $Content='Hello!';
 
 //下面写出了一个HEREDOC,其中标识LABEL可以自定义为任何字符串,但要保证开头的标识和结尾的标识一样
 echo <<<LABEL
 $Content
 LABEL;
 //结尾的方法:另起一行,打上LABEL。注意结尾的标识前面和后面不要插入任何字符,空格也不行
 
 echo '<br>';//为了演示方便换行
 
 //NOWDOC和HEREDOC的书写方式差别在于NOWDOC的标识符需要用单引号包围
 echo <<<'LABEL'
 $Content
 LABEL;
 //其他无异
 
 ?>

也可以参考PHP.net上的关于这两个的wiki:https://wiki.php.net/rfc/heredoc-with-double-quotes

用HEREDOC/NOWDOC书写极好的解决了包围引号的问题,但依然没有解决语法着色失效的问题

3、HTML中嵌入PHP程序块(推荐)

这是一种非常合适的办法,并且这种方法广泛用在了诸如WordPress模板等场合中。书写起来也较为方便,直接在需要输出的地方写上相关的代码就行了,就像下面这样

<?php
 
 //首先在这里写好相关的调用代码
 function OutputTitle(){
   echo 'TestPage';
 }
 function OutputContent(){
   echo 'Hello!';
 }
 
 //然后再下面调用相关函数就可以了
 ?>
 
 <!DOCTYPE html>
 <html>
   <head>
     <title><?php OutputTitle(); ?></title>
   </head>
   <body>
     <span><?php OutputContent(); ?></span>
   </body>
 </html>

我认为这种方法是在这三种方法中最好的,但是这样做的缺点是如果这样的代码块一多了就会严重影响程序阅读。

4、使用前端模板引擎

由于前端的重要性在整个Web开发中日益上升,现在前/后端工程师逐渐在分离成两个职业,所以说为了确保前/后端工程师能够相互配合,使前端开发和后端开发出来的东西对接更完美,逐渐催生出了一系列前端模板引擎,比如Smarty。使用Smarty书写的实现代码可读性非常的高,这使前/后端的分离也更加的高效和便捷。有兴趣的同学可以去搜索了解

以上这篇PHP/HTML混写的四种方式总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
PHP循环获取GET和POST值的代码
Apr 09 PHP
一步一步学习PHP(4) php 函数 补充2
Feb 15 PHP
php异常:Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE  eval()'d code error
May 19 PHP
Look And Say 序列php实现代码
May 22 PHP
关于file_get_contents返回为空或函数不可用的解决方案
Jun 24 PHP
PHP利用REFERER根居访问来地址进行页面跳转
Sep 28 PHP
php获取文件大小的方法
Feb 26 PHP
PHP读取RSS(Feed)简单实例
Jun 12 PHP
PHP实现获取客户端IP并获取IP信息
Mar 17 PHP
php递归函数三种实现方法及如何实现数字累加
Aug 07 PHP
PHP封装的XML简单操作类完整实例
Nov 13 PHP
PHP调用接口API封装的例子
Oct 11 PHP
老生常谈文本文件和二进制文件的区别
Feb 27 #PHP
php实现数据库的增删改查
Feb 26 #PHP
php查询及多条件查询
Feb 26 #PHP
php批量删除操作代码分享
Feb 26 #PHP
浅谈PHP的反射API
Feb 26 #PHP
CentOS 上搭建 PHP7 开发测试环境
Feb 26 #PHP
php封装的验证码类分享
Feb 26 #PHP
You might like
解决php中Cannot send session cache limiter 的问题的方法
2007/04/27 PHP
PHP获取MAC地址的函数代码
2011/09/11 PHP
set_exception_handler函数在ThinkPHP中的用法
2014/10/31 PHP
PHP编程获取音频文件时长的方法【基于getid3类】
2017/04/20 PHP
PHP命名空间与自动加载类详解
2018/09/04 PHP
laravel框架查询数据集转为数组的两种方法
2019/10/10 PHP
jquery.simple.tree插件 更简单,兼容性更好的无限树插件
2010/09/03 Javascript
网络之美 JavaScript中Get和Set访问器的实现代码
2010/09/19 Javascript
js有关元素内容操作小结
2011/12/20 Javascript
js 操作select与option(示例讲解)
2013/12/20 Javascript
详解javascript new的运行机制
2016/01/26 Javascript
BootStrap modal模态弹窗使用小结
2016/10/26 Javascript
jQuery webuploader分片上传大文件
2016/11/07 Javascript
在点击div中的p时,如何阻止事件冒泡
2017/02/07 Javascript
jQuery的中 is(':visible') 解析及用法(必看)
2017/02/12 Javascript
详解在vue-cli项目中安装node-sass
2017/06/21 Javascript
angular实现spa单页面应用实例
2017/07/10 Javascript
Vuex modules模式下mapState/mapMutations的操作实例
2019/10/17 Javascript
Servlet返回的数据js解析2种方法
2019/12/12 Javascript
JavaScript动态生成表格的示例
2020/11/02 Javascript
Nest.js散列与加密实例详解
2021/02/24 Javascript
Python实现将绝对URL替换成相对URL的方法
2015/06/28 Python
Python通过DOM和SAX方式解析XML的应用实例分享
2015/11/16 Python
解析Python中的生成器及其与迭代器的差异
2016/06/20 Python
Pandas:DataFrame对象的基础操作方法
2018/06/07 Python
Python Opencv任意形状目标检测并绘制框图
2019/07/23 Python
欧洲最大的美妆零售网站:Feelunique
2017/01/14 全球购物
泰国第一的化妆品网站:Konvy
2018/02/25 全球购物
Manduka官网:瑜伽垫、瑜伽毛巾和服装
2018/07/02 全球购物
校班主任推荐信范文
2013/12/03 职场文书
小学生倡议书范文
2014/05/13 职场文书
工作说明书格式
2014/07/29 职场文书
车间统计员岗位职责
2015/04/14 职场文书
2015小学教育教学工作总结
2015/07/21 职场文书
Vue vee-validate插件的简单使用
2021/06/22 Vue.js
JavaScript中MutationObServer监听DOM元素详情
2021/11/27 Javascript