變量的變量,PHP和妳

日期:2006-06-01  作者:喜騰小二  來源:PHPChina


在我最近做的一個項目中,我發現了一個新的概念,關於在PHP中使用變量的變量。在我的程序中,我需要在一個页面同時更新多個記錄,在我經?嗟背な奔涞耐純嗨妓髦?螅?院V信既壞厣料殖隽吮淞康謀淞浚?ariable variable)這一概念,所有的困惑就一掃而光了。
介紹
什麼叫作變量的變量?根據PHP手冊,變量的變量是指取得一個變量的值並把它作為另一個變量的變量名。這表述顯得相當的直接,容易和那些在一個句子中使用“變量”這個詞弄混淆。給一個簡單的例子,妳定義一個變量 --- x 等於 this --- 然後定義一個變量的變量,意味着妳把 x 的值作為新變量的名,在這個例子中,這個新變量的值是 is cake。用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 "

n";
echo "n";
echo "".
"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("

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 "n";
echo "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";
$result = mysql_query($sql);
}
}
?>
我希望這有助於妳明白這個變量的變量的基本用法,並且在妳將來的工作中使用它們提供一些思路。變量的變量這一概念,最初也是讓我頭痛的東西,但是一旦妳知道了它們工作的基本原理時,它們就變成了一塊美味的比薩餅。

<<<返回技術中心

技術文章

站內新聞

Posted ByLinkDescriptionApproved
YesNo