作者liaosankai (低溫烘焙)
看板PHP
標題Re: [請益] 如何讀取php內物件的名稱?
時間Sat Jun 18 11:48:58 2011
用序號來產生當做input的name,像是username1、username2…倒也不算是不行。
只不過這樣的作法有點不太漂亮,應該要善用陣列方式的name,下列我就貼個範例
[a.html][b.php]的程式碼部分。
====================================
[a.html] ※當然這些HTML你也可以用PHP去產生
<form action="b.php" method="post">
<!--第一組資料-->
是否參加:<input name="join[]" type="checkbox" value="1" checked="checked" />
人物名稱:<input name="username[]" type="text" value="Jack" />
<hr />
<!--第二組資料-->
是否參加:<input name="join[]" type="checkbox" value="1" />
人物名稱:<input name="username[]" type="text" value="Jennifer" />
<input type="submit" value="送出" />
</form>
===================================
[b.php]
//我們來看一下$_POST的資料結構
print_r($_POST);
/*輸出結果:
Array
(
[join] => Array
(
[0] => 1
)
[username] => Array
(
[0] => Jack
[1] => Jennifer
)
)*/
很好,$_POST的資料已經變成陣列了,不過這樣的陣列結構並不適合
我們處理,我們希望他能夠是同組資料為一個陣列(ROW),所以必需將
陣列變個小變化
/**
* 旋轉陣列
*/
function rotate($source_array, $keep_keys = TRUE){
$new_array = array();
foreach ($source_array as $key => $value){
$value = ($keep_keys === TRUE) ? $value : array_values($value);
if(is_array($value)){
foreach ($value as $k => $v){
$new_array[$k][$key] = $v;
}
}
}
return $new_array;
}
//將$_POST資料進行旋轉
$data = rotata($_POST);
print_r($data);
/*輸出結果:
Array
(
[0] => Array
(
[join] => 1
[username] => Jack
)
[1] => Array
(
[username] => Jennifer
)
)*/
現在陣列已變成適合我們處理的結構了
foreach($data as $key => $row){
echo "第{$key}筆資料";
echo '是否參加:' . ($row['join'])? '是': '否';
echo "人物名稱:{$row['username']}";
}
--
歡迎來我的網誌看看
@
http://liaosankai.pixnet.net/blog
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 123.240.225.236
推 kusoayan:推 06/18 12:12
推 mrbigmouth:坦白說 我覺得這只是習慣問題而已 談不上比較漂亮啦... 06/18 12:41
→ mrbigmouth:如果要做的是"從資料庫中讀取一堆多選題"... 06/18 12:42
→ mrbigmouth:終究還是要在input的name上做功夫的 06/18 12:43
→ mrbigmouth:那還不如一開始就習慣改input name 06/18 12:44
推 mrbigmouth:不過現在這題好像用陣列比較好= = 都是checkbox... 06/18 13:14
→ mrbigmouth:剛剛才發現...這樣中間沒選後面就全讀不到了XDDrz 06/18 13:15
推 a3343554:對= = 06/18 13:16
推 appleboy46:中間如果沒有選 checkbox 會有問題 06/18 13:38
→ liaosankai:XD 實作上當然有些要考慮地方,旋轉函式也可以再加強 06/18 14:15