文章來源:http://www.cnblogs.com/techmoe/p/4611658.html
PHP作為一款後端語言,為了輸出給瀏覽器讓瀏覽器呈現出來,無可避免的要輸出HTML代碼,下文介紹下我用過的三種PHP/HTML混編方法
1.單/雙引號包圍法
這是最初級的方法了,用法就像下面這樣
1 <?php
2 echo '
3 <!DOCTYPE html>
4 <html>
5 <head>
6 <title> </title>
7 </head>
8 <body>
9 <span>測試頁面</span>
10 </body>
11 </html>
12 ';
13 ?>
這樣是最簡單的一種方法了,直接用單引號包裝上就行了
至於雙引號和單引號的區別,就在於
前者解析引號內的變量,而後者不解析引號內的變量,參看下面的例子
1 <?php
2 $Content='Hello!';
3 echo "$Content";
4 echo '<br>';
5 echo '$Content';
6 ?>
輸出
1 Hello!
2 $Content
由此可見,用雙引號包圍的字符串中的變量名自動解析為了變量值,而用單引號包圍則依然顯示變量名
這樣書寫的缺點有兩點
1.如果輸出內容中包含單/雙引號將極難處理,因為PHP無法判斷這個引號是屬於程序的還是輸出內容的,所以會報錯
2.這樣書寫一些現代文本編輯器(如SublimeText)將無法對引號包圍的輸出的內容進行語法著色,如果出現一些格式問題將極難發現。圖中為SublimeText3的一張截圖,上面的是正常的著色,下面則是用引號包圍的著色
2.使用HEREDOC/NOWDOC
HEREDOC和NOWDOC是PHP5.3開始支持的一種新特性,它允許在程序中使用一種自定義的標志符來包圍文本,而HEREDOC和NOWDOC的關系就類似於雙引號包圍和單引號包圍一樣,
前者解析區塊內的變量,而後者不解析區塊內的變量下面介紹HEREDOC和NOWDOC的用法
1 <?php
2 $Content='Hello!';
3
4 //下面寫出了一個HEREDOC,其中標識LABEL可以自定義為任何字符串,但要保證開頭的標識和結尾的標識一樣
5 echo <<<LABEL
6 $Content
7 LABEL;
8 //結尾的方法:另起一行,打上LABEL。注意結尾的標識前面和後面不要插入任何字符,空格也不行
9
10 echo '<br>';//為了演示方便換行
11
12 //NOWDOC和HEREDOC的書寫方式差別在於NOWDOC的標識符需要用單引號包圍
13 echo <<<'LABEL'
14 $Content
15 LABEL;
16 //其他無異
17
18
19 ?>
也可以參考PHP.net上的關於這兩個的wiki:https://wiki.php.net/rfc/heredoc-with-double-quotes
用HEREDOC/NOWDOC書寫極好的解決了包圍引號的問題,但依然沒有解決語法著色失效的問題
3.HTML中嵌入PHP程序塊(推薦)
這是一種非常合適的辦法,並且這種方法廣泛用在了諸如WordPress模板等場合中。書寫起來也較為方便,直接在需要輸出的地方寫上相關的代碼就行了,就像下面這樣
1 <?php
2
3 //首先在這裏寫好相關的調用代碼
4 function OutputTitle(){
5 echo 'TestPage';
6 }
7 function OutputContent(){
8 echo 'Hello!';
9 }
10
11 //然後再下面調用相關函數就可以了
12 ?>
13
14 <!DOCTYPE html>
15 <html>
16 <head>
17 <title><?php OutputTitle(); ?></title>
18 </head>
19 <body>
20 <span><?php OutputContent(); ?></span>
21 </body>
22 </html>
我認為這種方法是在這三種方法中最好的,但是這樣做的缺點是如果這樣的代碼塊一多了就會嚴重影響程序閱讀。
4.使用前端模板引擎
由於前端的重要性在整個Web開發中日益上升,現在前/後端工程師逐漸在分離成兩個職業,所以說為了確保前/後端工程師能夠相互配合,使前端開發和後端開發出來的東西對接更完美,逐漸催生出了一系列前端模板引擎,比如Smarty。使用Smarty書寫的實現代碼可讀性非常的高,這使前/後端的分離也更加的高效和便捷。有興趣的同學可以去搜索了解