变量的变量,PHP和你
2024-05-04 22:56:25
供稿:网友
菜鸟学堂:
在我最近做的一个项目中,我发现了一个新的概念,关于在php中使用变量的变量。在我的程序中,我需要在一个页面同时更新多个记录,在我经过相当长时间的痛苦思索之后,脑海中偶然地闪现出了变量的变量(variable variable)这一概念,所有的困惑就一扫而光了。
介绍
什么叫作变量的变量?根据php手册,变量的变量是指取得一个变量的值并把它作为另一个变量的变量名。这表述显得相当的直接,容易和那些在一个句子中使用“变量”这个词弄混淆。给一个简单的例子,你定义一个变量 --- x 等于 this --- 然后定义一个变量的变量,意味着你把 x 的值作为新变量的名,在这个例子中,这个新变量的值是 is cake。用php来表示如下:
<?php
$x = "this";
$$x = "is cake";
?>
这个符号$$是在php中对变量的变量的表示方法。现在我们可以用两种不同的方式来引用这两个变量 $x 和 $$x 了。
<?php
echo "$x ${$x}";
?>
<?php
echo "$x $this";
?>
上面两段程序都将输出 this is cake。注意,在echo语句中$$x被写成${$x},这是让php知道你要输出的是变量的变量而不是一个$字符与$x变量。
你是不是仍很迷惑?哦,也许吧,你想要一些更深入更有用的例子?下一节,我将向你展示怎样用变量的变量在一个页面编辑多条记录的。
例子
假设你已有一个mysql数据库,保存了对一些感兴趣的站点的链接,库中有一个表submissions,字段如下:
submissionid
postedby
link
description
approved
现在你想显示在表中所有的已创建但没有被认可的链接,这个编辑的页面应可以更正一些输入时的错误,并用适当的单选按钮来为每一个记录设置是否允许(approved),然后一次把更新后的记录都提交到表中。
首先,当你从数据库出提取所有的记录并显示出来时,你必须为每一个记录设置一个唯一的名字,这将让我们在提交时可以循环地辩别出各个记录的值。代码如下:
<?php
//初始化变量的记数器
$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变量再一次循环遍历页面上所有的变量,然后,分配这些变量给另一些变量,这就用到了变量的变量。
<?php
//这个循环遍历所有页面上显示的记录
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);
}
}
?>
我希望这有助于你明白这个变量的变量的基本用法,并且在你将来的工作中使用它们提供一些思路。变量的变量这一概念,最初也是让我头痛的东西,但是一旦你知道了它们工作的基本原理时,它们就变成了一块美味的比萨饼。