首頁 > 後端開發 > php教程 > PHP/HTML混寫的四種方式

PHP/HTML混寫的四種方式

高洛峰
發布: 2023-03-06 08:24:02
原創
1705 人瀏覽過

PHP作為一款後端語言,為了輸出給瀏覽器讓瀏覽器呈現出來,無可避免的要輸出HTML程式碼,下文介紹下我用過的三種PHP/HTML混合方法

1、單/雙引號包圍法

這是最初級的方法了,用法就像下面這樣

<?php  echo &#39;
 <!DOCTYPE html>
 
   
     <title> </title>
   
   
     <span>测试页面</span>
   
 
 ';
?>
登入後複製

這樣是最簡單的一種方法了,直接用單引號包裝上就行了

至於雙引號和單引號的區別,就在於前者解析引號內的變量,而後者不解析引號內的變量,參考下面的例子

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

也可以參考PHP.net上的關於這兩個的wiki:https://wiki.php.net/rfc/heredoc-with-double-quotes

#用HEREDOC/NOWDOC書寫極好的解決了包圍引號的問題,但依然沒有解決語法著色失效的問題

3、HTML中嵌入PHP程式區塊(建議)

這是一種非常合適的辦法,並且這種方法廣泛用在了諸如WordPress模板等場合中。寫起來也較為方便,直接在需要輸出的地方寫上相關的程式碼就行了,就像下面這樣

<?php  
 //首先在这里写好相关的调用代码
 function OutputTitle(){
   echo &#39;TestPage&#39;;
 }
 function OutputContent(){
   echo &#39;Hello!&#39;;
 }
 
 //然后再下面调用相关函数就可以了
 ?>
 
 nbsp;html>
 
   
     <title><?php  OutputTitle(); ?></title>
   
   
     <span><?php  OutputContent(); ?></span>
   
 
登入後複製

我認為這種方法是在這三種方法中最好的,但是這樣做的缺點是如果這樣的程式碼區塊一多了就會嚴重影響程式閱讀。

4、使用前端模板引擎

由於前端的重要性在整個Web開發中日益上升,現在前/後端工程師逐漸在分離成兩個職業,所以說為了確保前/後端工程師能夠相互配合,使前端開發和後端開發出來的東西對接更完美,逐漸催生出了一系列前端模板引擎,例如Smarty。使用Smarty書寫的實作程式碼可讀性非常的高,這使前/後端的分離也更加的高效和便捷。有興趣的同學可以去搜尋了解

以上這篇PHP/HTML混寫的四種方式總結就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持PHP中文網。

更多PHP/HTML混寫的四種方式相關文章請關注PHP中文網!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板