php和html混编的三种方式

 

第一种是在HTML中加PHP。

大段大段的html代码中,在各个需要执行php的地方<?php .... ?>。这种方法在ASP的程序中比较常见。 
例子: 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<meta http-equiv="Content-Language" content="zh-CN" /> 
<title>Hello World</title><style>body{font-size:15px;color:#000;font-family:Arial,Helvetica,sans-serif;}a{color:#039;text-decoration:none;}</style> 
</head>

<body>

<?php 

echo "Hello world!这是正文"; 
?> 
</body></html>  

第二种用echo输出HTML。

但是HTML中有双引号,所用echo输出的内容用单引号括起来,避免出错,也省了转义这一步。比如这样的代码: 

<?php 
if(!$_POST) 

echo '<form action="" method="post"> 

服务器地址:<input type="text" name="host" value="localhost" /><br /> 
数据库账号:<input type="text" name="user" value="" /><br /> 
数据库密码:<input type="password" name="pwd" value="" /><br /> 
指定数据库:<input type="text" name="db" value="test" /><br /> 
<input type="submit" value="确定"/> 
</form><hr/>说明:<b><br /></b>'; 

?>  
不过比较多见的还是加了转义符号的,个人觉得阅读起来不爽 
echo "<input type=\"submit\" value=\"确定\"/>"  

第三种就是用(<<<)标记符了。

这是在PHP5+出现的方式。 
<<<EOT 
EOT;  
中间的文档直接输出,一个比较好理解的说法是“一个多行的echo ”。 
优点是输出大段HTML方便,不需要转义,而且可以引用变量。一个例子: 

<?php 
print <<<EOT 
<div class="slidecont">{$label[deepblue_mainslide]}</div> 
<div class="newcontainter"> 
<div class="head">{$label[deepblue_mainh1]}</div> 
<div class="cont" id="Tab1"> 
{$label[deepblue_maint1]} 
</div> 
<div class="cont" id="Tab2"> 
{$label[deepblue_maint2]} 
</div> 
</div> 
<a href="$rs[url]" title="$rs[descrip]" target="_blank">$rs[name]</a> 
EOT; 
?>  
在上面的例子干净利索的输出了大段HTML+变量的值,非常棒。 
注意:可以多次使用EOT方式输出,但是<<<EOT后和EOT;前都不能有空格,而且EOT;要独占一行! 

posted @ 2020-03-01 17:20  nxmxl  阅读(1436)  评论(0编辑  收藏  举报