天天看點

變量的變量,PHP和你

在我最近做的一個項目中,我發現了一個新的概念,關于在PHP中使用變量的變量。在我的程式中,我需要在一個頁面同時更新多個記錄,在我經過相當長時間的痛苦思索之後,腦海中偶然地閃現出了變量的變量(variable variable)這一概念,所有的困惑就一掃而光了。

介紹

什麼叫作變量的變量?根據PHP手冊,變量的變量是指取得一個變量的值并把它作為另一個變量的變量名。這表述顯得相當的直接,容易和那些在一個句子中使用“變量”這個詞弄混淆。給一個簡單的例子,你定義一個變量 --- x 等于 this --- 然後定義一個變量的變量,意味着你把 x 的值作為新變量的名,在這個例子中,這個新變量的值是 is cake。用PHP來表示如下:

<?php

$x = "this";

$$x = "is cake";

?>

這個符号$$是在PHP中對變量的變量的表示方法。現在我們可以用兩種不同的方式來引用這兩個變量 $x 和 $$x 了。

echo "$x ${$x}";

echo "$x $this";

上面兩段程式都将輸出 this is cake。注意,在echo語句中$$x被寫成${$x},這是讓PHP知道你要輸出的是變量的變量而不是一個$字元與$x變量。

你是不是仍很迷惑?哦,也許吧,你想要一些更深入更有用的例子?下一節,我将向你展示怎樣用變量的變量在一個頁面編輯多條記錄的。

例子

假設你已有一個MySQL資料庫,儲存了對一些感興趣的站點的連結,庫中有一個表submissions,字段如下:

SubmissionID

PostedBy

Link

Description

Approved

現在你想顯示在表中所有的已建立但沒有被認可的連結,這個編輯的頁面應可以更正一些輸入時的錯誤,并用适當的單選按鈕來為每一個記錄設定是否允許(Approved),然後一次把更新後的記錄都送出到表中。

首先,當你從資料庫出提取所有的記錄并顯示出來時,你必須為每一個記錄設定一個唯一的名字,這将讓我們在送出時可以循環地辯别出各個記錄的值。代碼如下:

//初始化變量的記數器

$index = 0;

$index_count = 0;

echo "<form method=post action=$PHP_SELF>n";

echo "<table>n";

echo "<tr><td><b>Posted By</b></td><td><b>Link</b></td>".

"<td><b>Description</b></td><td><b>Approved</b></td></tr>n";

/*********

假定我們已從資料庫中檢索出記錄到一個數組中 

$myrow = mysql_fetch_array().

下面的 do...while 循環根據名字為每一個$xstr變量配置設定了一個值并且連接配接了$index 的值到結尾,以0為開始。

這樣,這個循環的第一次時,$SubmissionIDStr 的值就是 SubmissionID0 ,第二次就是 SubmissionID1 ,以此類推。

***********/

do {

$SubmissionIDStr = SubmissionID.$index;

$PostedByStr = PostedBy.$index;

$LinkStr = Link.$index;

$DescriptionStr = Description.$index;

$ApprovedStr = Aprroved.$index;

//這一段将在螢幕上顯示值,以每行一條記錄。

printf("<tr><td><input type=hidden name=%s value=%s><input type=text name=%s value=%s></td>

<td><input type=text name=%s value=%s></td><td><input type=text name=%s value=%s></td>

<td><input type=radio name=%s value=-1>Yes<input type=radio name=%s value=0 checked>No</td></tr>n",

$SubmissionIDStr, $myrow["SubmissionID"], $PostedByStr, $myrow["PostedBy"], $LinkStr, $myrow["Link"],

$DescriptionStr, $myrow["Description"], $ApprovedStr, $ApprovedStr);

//每個循環記數器加1

$index++;

$index_count++;

} while ($myrow = mysql_fetch_array($result));

// 建立一個索引記數器index_count來跟蹤所有的記錄數

echo "<INPUT TYPE=hidden NAME=counter VALUE=$index_count>n";

echo "<INPUT TYPE=submit></form>n";

送出以後,我們利用$index_count變量再一次循環周遊頁面上所有的變量,然後,配置設定這些變量給另一些變量,這就用到了變量的變量。

//這個循環周遊所有頁面上顯示的記錄

for ($index = 0; $index <= $counter; $index++) {

/*****

這部分用我們在前面建立的名字設定了新的變量

從0開始,直到$index_count

*****/

$varSubmissionID = 'SubmissionID'.$index;

$varPostedBy = 'PostedBy'.$index;

$varLink = 'Link'.$index;

$varDescription = 'Description'.$index;

$varApproved = 'Approved'.$index;

/******

這是變量的變量部分,把每個值配置設定給每個新變量的名。

例如,第一次循環時,配置設定給記錄 SubmissionID0 是從前面得來的值,我們用變量的變量來了取到它。

*******/

$SubmissionIDvalue = $$varSubmissionID;

$PostedByvalue = $$varPostedBy;

$Linkvalue = $$varLink;

$Descriptionvalue = $$varDescription;

$Approvedvalue = $$varApproved;

//更新資料庫

$sql = "UPDATE submissions SET PostedBy='$PostedByvalue',Link='$Linkvalue',".

"Description='$Descriptionvalue' WHERE SubmissionID=$SubmissionIDvalue'";

$result = mysql_query($sql);

//如果本記錄被設定為approved,更新相應的字段 Approved。

if ($Approvedvalue == '-1') {

$sql = "UPDATE submissions SET Approved='-1' WHERE SubmissionID=$SubmissionIDvalue";

}

我希望這有助于你明白這個變量的變量的基本用法,并且在你将來的工作中使用它們提供一些思路。變量的變量這一概念,最初也是讓我頭痛的東西,但是一旦你知道了它們工作的基本原理時,它們就變成了一塊美味的比薩餅。