php
<?php session_start(); session_regenerate_id(true); if(isset($_SESSION['member_login'])==false){ echo'ようこそゲスト様 '; echo'<a href="./membert_login.html">会員ログイン</a><br/>'; echo'<br/>'; }else{ echo $_SESSION['member_name']; echo'様<br/>'; echo'<a href="member_logout.php">ログアウト</a><br/>'; echo'</br>'; } ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <?php try{ $cart=$_SESSION['cart']; $kazu=$_SESSION['kazu']; $max=count($cart); $dsn='mysql:dbname=shop;host=localhost;charset=utf8'; $user='kakeaki'; $password='kakeaki'; $dbh=new PDO($dsn,$user,$password); $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); foreach($cart as $key=>$val){ //セッションに入っているcodeを入れている $sql='SELECT code,name,price,gazou FROM mst_product WHERE code=?'; $stmt=$dbh->prepare($sql); $data[0]=$val; $stmt->execute($data); $rec=$stmt->fetch(PDO::FETCH_ASSOC); $pro_name[]=$rec['name']; $pro_price[]=$rec['price']; if($rec['gazou']==''){ $pro_gazou[]=''; }else{ $pro_gazou[]='<img src="../product/gazou/'.$rec['gazou'].'">'; } } $dbh=null; }catch(Exception $e){ echo'ただいま障害により大変ご迷惑をお掛けしています '; exit(); } ?> カートの中身</br> </br> <form method="post" action="kazu_change.php"> <?php for($i=0;$i<$max;$i++){ ?> <?php echo $pro_name[$i];?> <?php echo $pro_gazou[$i];?> <?php echo $pro_price[$i];?>円 <input type="text" name="kazu<?php echo $i;?>" value="<?php echo $kazu[$i];?>"> <?php echo $pro_price[$i]*$kazu[$i];?>円 <br/> <?php } ?> <br/> <input type="hidden" name="max" value="<?php echo $max;?>"> <input type="submit" value="数量変更"><br/> <input type="button" onclick="history.back()" value="戻る"> </form> </body> </html>
気づけばプロ並みPHP改訂版で勉強をしています。
foreach文についての質問です。
「$data[0]=$val;」ここの部分の[0]の役割がよくわかりません。本書では、「0と明示的に書いたのは、ルーフが回るたびに1,2,3,となってしまわないためです。」と書いてあるのですが理解できませんでした。
試しに、0ではなく1や2と書くとうまく機能しませんでした。また、「$data =$val;」このような形にしてもうまく機能しませんでした。
なぜ、「$data[0]=$val;」この形にしなければうまく機能しないのかわかりません。ご教授の方をよろしくお願いいたします。
まだ回答がついていません
会員登録して回答してみよう