能要求
在頁面中嵌入PHP代碼,通過PHP代碼中的echo語句在頁面中動(dòng)態(tài)輸出“Hello World!”。
實(shí)例代碼
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>在HTML頁面中嵌入PHP代碼</title>
</head>
<body>
HTML代碼<br />
<?php
echo "Hello World<br />";
?>
HTML代碼
</body>
</html>
運(yùn)行結(jié)果
代碼分析
<?php
"Hello World<br />";
?>:使用“<?php …… ?>”中框起來的代碼為PHP代碼,<?php之前的代碼和?>之后的代碼為標(biāo)準(zhǔn)的HTML代碼。<?php:是PHP代碼的開始標(biāo)記。?>:是PHP代碼的結(jié)束標(biāo)記。echo "Hello World<br />";:表示向?yàn)g覽器輸出字符串,后面用單引號(hào)包裹的內(nèi)容就是字符串,最后的分號(hào)“;”表示該語句結(jié)束,可以編寫下一條語句。如果在這條語句后面沒有下一條語句“;”可以省略,否則會(huì)報(bào)錯(cuò)。
功能要求
在頁面中嵌入PHP代碼,通過PHP代碼中的echo語句為頁面中顯示的信息改變字體和顏色。
實(shí)例代碼
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>在HTML頁面中嵌入PHP代碼</title>
</head>
<body>
<font color = "<?php echo 'red'; ?>">
<?php echo "<b><i>PHP</i></b>";?>初體驗(yàn)
</font>
</body>
</html>
運(yùn)行結(jié)果
代碼分析
PHP代碼可以嵌套到HTML的任何位置。
在PHP中實(shí)時(shí)將數(shù)據(jù)庫中的數(shù)據(jù)顯示在網(wǎng)頁上,您可以使用Ajax和PHP進(jìn)行無刷新更新。Ajax這個(gè)術(shù)語源自描述從基于Web的應(yīng)用到基于數(shù)據(jù)的應(yīng)用,它不是一種新的編程語言,而是一種用于創(chuàng)建更好更快以及交互性更強(qiáng)的Web應(yīng)用程序的技術(shù)。Ajax在瀏覽器與Web服務(wù)器之間使用異步數(shù)據(jù)傳輸,這樣就可以使網(wǎng)頁從服務(wù)器請(qǐng)求少量的信息,而不是整個(gè)頁面。下面是一個(gè)簡單的示例:
1.在您的HTML文件中,創(chuàng)建一個(gè)div元素來顯示數(shù)據(jù)庫中的數(shù)據(jù)。
<div id="data-container"></div>
2.在PHP文件中,編寫一個(gè)從數(shù)據(jù)庫中檢索數(shù)據(jù)的腳本來返回?cái)?shù)據(jù)并將其插入到HTML文件中。
<?php
// 連接到數(shù)據(jù)庫
// ...
// 從數(shù)據(jù)庫中檢索數(shù)據(jù)
$data = // ... 查詢語句 ...;
// 將數(shù)據(jù)插入到HTML文件中
$html = '<p>'.implode('<br>', $data).'</p>';
// 輸出有意義的HTTP頭部
header('Content-type: text/html');
// 輸出HTML文件中的數(shù)據(jù)
echo $html;
?>
3.在您的JavaScript文件中,使用Ajax技術(shù)調(diào)用PHP腳本并將結(jié)果插入到div元素中。
function updateData() {
// 創(chuàng)建Ajax請(qǐng)求
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
// 更新頁面上的數(shù)據(jù)容器
document.getElementById("data-container").innerHTML = this.responseText;
}
};
// 調(diào)用PHP腳本并傳遞參數(shù)(如果有的話)
xhttp.open("GET", "get_data.php", true);
xhttp.send();
}
// 每隔一段時(shí)間調(diào)用updateData()函數(shù)以獲取新數(shù)據(jù)
setInterval(updateData, 1000);
這樣,每當(dāng)指定的時(shí)間間隔過去時(shí),JavaScript文件就會(huì)通過Ajax調(diào)用PHP腳本,獲取最新的數(shù)據(jù)并將其插入到HTML文件中的指定位置。
累點(diǎn)滴,匯成江海。咱們從最最基礎(chǔ)的PHP知識(shí)開始學(xué)習(xí),一步一個(gè)腳印的開啟PHP的學(xué)習(xí)旅途吧。
請(qǐng)點(diǎn)擊右上角“關(guān)注”按鈕關(guān)注我們喲:跟著木辛老師學(xué)習(xí)PHP編程知識(shí),變身快樂的編程達(dá)人吧~
同學(xué)們好呀!木辛老師又來了。
咱們?cè)陂_始PHP的學(xué)習(xí)之前,需要先準(zhǔn)備一個(gè)可以提供PHP服務(wù)的Web服務(wù)器。我們就復(fù)用木辛老師專欄中的一個(gè)教程,使用Homestead本地開發(fā)環(huán)境進(jìn)行學(xué)習(xí)唄。
傳送門:《Laravel第一課:搭建Laravel開發(fā)環(huán)境》
也可以關(guān)注木辛老師的Laravel專欄喲:
大家配置好本地開發(fā)環(huán)境以后,還需要稍微設(shè)置一下,針對(duì)這個(gè)項(xiàng)目,在Homestead配置文件中作如下設(shè)置,
添加指向當(dāng)前項(xiàng)目根目錄的配置:
sites: - map: learning_php.test to: /Code/zyoo/learning_php to: /Code/zyoo/learning_php
另外還需要在本機(jī)hosts文件中添加一個(gè)域名指向:
sudo vim /etc/hosts
并添加如下記錄:
192.168.10.10 learning_php.test
最后,添加一個(gè)測試文件:
php代碼
然后,打開瀏覽器,訪問域名查看頁面結(jié)果
執(zhí)行效果
大家可以看到,我們已經(jīng)可以成功的訪問到測試用的PHP文件了。
好了,萬事俱備,只需要學(xué)習(xí)了。那么,咱們開始吧~
幾乎絕大部分服務(wù)器端的腳本語言最初設(shè)計(jì)的應(yīng)用場景之一就是處理HTML表單。木辛老師要翻出家底,將自己最心愛的在線圖書商城,用來作為學(xué)習(xí)PHP基礎(chǔ)知識(shí)的場景吧。
通過這個(gè)表單頁面,我們可以知道顧客訂購的商品,訂單的金額以及其他一些附屬信息。HTML代碼請(qǐng)看下方:
<html> <head> <title>木辛老師的PHP基礎(chǔ)入門教程</title> </head> <body> <form action="processorder.php" method="POST"> <table style="border: 0px;"> <tr style="background: #cccccc"> <td style="width: 150px;text-align:center;">圖書名稱</td> <td style="width: 50px;text-align:center;">數(shù)量</td> </tr> <tr> <td>PHP入門指南</td> <td><input type="text" name=“book_name_01" size="3" maxlength="3"/></td> </tr> <tr> <td>PHP和MySQL開發(fā)</td> <td><input type="text" name="book_name_02" size="3" maxlength="3"/></td> </tr> <tr> <td>Laravel入門</td> <td><input type="text" name="book_name_03" size="3" maxlength="3"/></td> </tr> <tr> <td colspan="2" style="text-align: center;"> <input type="submit" value="提交訂單"/> </td> </tr> </table> </form> </body> </html>
咱么直接通過瀏覽器訪問這個(gè)HTML頁面,看看效果:
頁面顯示
哈,簡單的頁面,我們已經(jīng)開啟Web開發(fā)神秘旅程了。繼續(xù)加油!
大家可能注意到了一個(gè)細(xì)節(jié):在html代碼的form表單部分,action屬性我們指向了一個(gè)php腳本:
<form action="processorder.php" method="POST”>
具體的PHP腳本的學(xué)習(xí)我們很快就能看到。這里只是稍微提一下,這個(gè)action屬性值就是用戶點(diǎn)擊“提交訂單”按鈕時(shí)將要請(qǐng)求的URL。
用戶在表單中輸入的數(shù)據(jù),會(huì)以POST的方式,發(fā)送給URL指向的PHP文件進(jìn)行處理。
那如何處理這個(gè)表單呢?又如何讓PHP代碼起作用的?
要處理這個(gè)表單,我們需要?jiǎng)?chuàng)建一個(gè)php文件,它的名字需要和form中action屬性的值保持一致。
那么,我們就創(chuàng)建一個(gè)名字叫做processorder.php的文件吧。
代碼可以先這么寫,看看是否能起作用哈:
<html> <head> <title>訂單處理結(jié)果</title> </head> <body> <h1> 木辛老師的在線圖書館</h1> <h2> 訂單處理結(jié)果通知</h2> <?php echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼 ?> </body> </html>
保持文件,并刷新頁面。這個(gè)時(shí)候我們點(diǎn)擊“提交訂單”按鈕,效果如下:
php執(zhí)行結(jié)果
大家可以看到,紅框部分就是通過PHP代碼輸出的結(jié)果。這樣,我們就實(shí)現(xiàn)了通過Web方式執(zhí)行了PHP代碼的需求,這么一看PHP還是非常簡單的吧。
我們順便在看看這個(gè)頁面的源代碼吧,看一下PHP代碼如何在HTML頁面中完成任務(wù)的吧:
源代碼
通過頁面源碼,我們發(fā)現(xiàn)剛才寫的PHP代碼已經(jīng)不見了,取而代之的是
<p>訂單已處理完成</p>
這是怎么回事呢?
這是因?yàn)镻HP解釋器在腳本運(yùn)行的時(shí)候,將該腳本的輸出替代了腳本自身的代碼,通過這種方式,就可以生成可以在任何瀏覽器上運(yùn)行的HTML頁面了。也就是說,瀏覽器是不需要學(xué)會(huì)PHP的。
通過這段代碼,我們可以學(xué)習(xí)一些PHP的基礎(chǔ)知識(shí):
第一種情況:在HTML中混寫PHP和HTML代碼,需要為php添加標(biāo)記。PHP代碼會(huì)以“<?php”作為開始,以“?>”作為結(jié)束。這些符號(hào)就叫做PHP標(biāo)記,它們主要用來告訴服務(wù)器PHP代碼的開始和截止,在這兩個(gè)起止符號(hào)之間的任何代碼,服務(wù)器都會(huì)以PHP語法來解析。
另一種情況:之后,我們寫純PHP的時(shí)候,每個(gè)文件也需要添加PHP標(biāo)記。不過呢,結(jié)束標(biāo)記可以省略,這也是很大一部分PHPer默認(rèn)遵守的規(guī)則。
在PHP的開始和截止標(biāo)記之間,就是PHP語句了,通過這些內(nèi)容可以告訴PHP解釋器應(yīng)該進(jìn)行如何的操作,在我們這個(gè)例子里,通過:
echo '<p>訂單已處理完成</p>’;
使用echo語句完成了一個(gè)非常簡單的操作,僅是將echo后邊的字符串原樣打印到瀏覽器中。這里需要特別注意的一點(diǎn)就是每個(gè)PHP語句后邊都需要添加英文的分號(hào)作為語句的結(jié)束符,否則會(huì)出現(xiàn)錯(cuò)誤,但是在這個(gè)html頁面中,因?yàn)橹挥幸痪浯a,忽略掉分號(hào)也是不會(huì)報(bào)錯(cuò)的。
但是還是強(qiáng)烈建議大家養(yǎng)成習(xí)慣:每句PHP代碼結(jié)束都要以分號(hào)結(jié)尾喲!
一般情況下,為了讓代碼更加清晰和整潔,在編碼的過程中會(huì)添加一些空格,這些空格包括:回車換行、空格、制表符等都被認(rèn)為是空格。
當(dāng)然了,瀏覽器并不會(huì)在意你是否輸入了空格,同樣的PHP服務(wù)器端解析器也會(huì)忽略這些,這些空格僅是給編寫代碼的人看的。
但是,木辛老師還是再次強(qiáng)烈建議,在代碼的適當(dāng)位置添加空格或者空行,這樣做可以很有效的提升代碼的可閱讀性,方便后期的維護(hù)工作。
最后在講講注釋,理論上在編程中出現(xiàn)頻率非常高的一個(gè)知識(shí)點(diǎn)。
為什么說理論上呢,因?yàn)檫@么重要的一個(gè)要點(diǎn),在實(shí)際開發(fā)中很容易被廣大開發(fā)者忽略呢!
由于種種原因吧,開發(fā)者很不習(xí)慣在開發(fā)過程中寫非常詳盡的注釋,而且有時(shí)候在Git提交時(shí)也是草草的一筆帶過。這樣做的后果就是,若干時(shí)間后,當(dāng)你再次拿到這段代碼,可能會(huì)花費(fèi)更多的時(shí)間梳理它。
所以,善于寫注釋,也是提高生產(chǎn)效率的一種有效手段。
PHP解釋器同樣會(huì)在執(zhí)行的時(shí)候忽略掉注釋,也就是說就好比像空格一樣,PHP解析器會(huì)跳過注釋,它只負(fù)責(zé)執(zhí)行PHP代碼!
PHP腳本中的注釋比較豐富,有很多類似C語言的風(fēng)格,比如:
多行注釋:
/* 這是 一個(gè) 多行 注釋 /*
可以看出來,多行注釋以 /*開始,以*/結(jié)束。同樣的和C語言是一樣的,多行注釋是不能嵌套的。
當(dāng)然了,除了多行注釋之外,也支持單行注釋:
echo '<p>訂單已處理完成</p>'; // 這里是PHP的代碼
或者這種:
echo '<p>訂單已處理完成</p>’; #這里是PHP的代碼
不論采取哪種風(fēng)格的注釋,在注釋符號(hào)之后的所有內(nèi)容,PHP解釋器都會(huì)認(rèn)識(shí)不需要處理的,這一點(diǎn)一定要注意呀!
好了,今天的課程咱就先講到這里。
小朋友們不要忘記關(guān)注我們喲 ,下期課程更精彩,請(qǐng)大家一起期待吧~
快樂編程,快樂成長,拜拜!
*請(qǐng)認(rèn)真填寫需求信息,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。