|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
算是1个熟悉的过程,所以c语言的基础有就更好,没有也不怕。变量 在我比来做的一个项目中,我发明了一个新的概念,关于在PHP中利用变量的变量。在我的法式中,我需求在一个页面同时更新多个纪录,在我经由相当长工夫的疾苦思考以后,脑海中偶尔地闪现出了变量的变量(variable variable)这一概念,一切的猜疑就一扫而空了。
<b>引见</b>
甚么叫作变量的变量?依据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变量。
你是否是仍很利诱?哦,或许吧,你想要一些更深切更有效的例子?下一节,我将向你展现如何用变量的变量在一个页面编纂多笔记录的。
<b>例子</b>
假定你已有一个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);
}
}
?>
我但愿这有助于你分明这个变量的变量的根基用法,而且在你未来的任务中利用它们供应一些思绪。变量的变量这一概念,最后也是让我头痛的器材,然而一旦你晓得了它们任务的根基道理时,它们就酿成了一块厚味的比萨饼。假如有甚么成绩请让我晓得吧。
最近陆续的有人问我学习php的心得,现在整理为下面,希望可以对大家有些帮助。 |
|