php - 获取用户选择的项目的 id?

标签 php html mysql arrays post

在phtml文件中显示我的所有数据库在一个表中,包括priceid等,然后在php文件Details中用户尝试按租金,它会获取商品的 ID 并使用 add 方法将其存储在商店中,但我不断收到此错误

Fatal error: Function name must be a string.

我从数据库存储项目 ID 的原因是,当用户 checkout 时,我将使用用户选择的项目 ID 检索所有信息。而且我还使用数组列表来存储多个项目,另一件事是他们获取项目 id 的方法是通过局部变量 $tem = $_POST(['$dvdDetails->getDvdId() ']); 在添加购物车文件中,但我不确定它是否存储了正确的值,因为存在 foreach 循环,并且变量的持续时间将在方法结束时被扭曲,所以我怎样才能获取所选项目的 id。

<?php
    require_once('Models/Product.php');

    class Shop {
         private $_products = array();

        public function getProducts() 
            { return $this->_products;}

        public function addProduct(Product $product) 
            { $this->_products[] = $product; 
              return $this;
            }

    }

    ?>


    <?php


    class Option {
      private $_optionKey;
        private $_optionValue;

        public function getKey()
            { return $this->_optionKey; }

        public function getVlue()
            { 
            return $this->_optionValue; 

            }

        public function setOption($key, $value)
            { 
              $this->_optionKey = $key;
              $this->_optionValue = $value;
              return $this;
            }
    }

    ?>


    <?php
    require_once('Models/Option.php');



    class Product {
        private $_options = array();

        public function getOptions()
            { return $this->_options; }

        public function addOption(Option $option)
            { $this->_options[] = $option;
              return $this;
            }
    }

    ?>
    //SHow all 
    <?php require('template/header.phtml') ?> 
    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post"> 

     <table class="datatable"> 
     <tbody> 

     <?php foreach ($view->dd as $dvdDetails) { 

     echo '<tr> <td>' 
           .'<img src="images/'. $dvdDetails->getPhotoDetails() .'"alt="no picture" height="240" width="820" />' .'<br><br>'.'<font size="3" color="#2E2E2E"><center>'. $dvdDetails->getDvdPhoto(). '</center></font>'.
             '<br><br><br>'.  '<font size="2" color="blue"><strong>Genre: </strong></font>'.  $dvdDetails->getDvdGenre() .
              '<br><br>'. '<font size="2" color="blue"><strong>Director: </strong></font>'.  $dvdDetails->getDvdDirector() . '<br><br>' .'<font size="2" color="blue"><strong>Ritels: </strong></font>'. $dvdDetails->getDvdRitels() .
             '<br><br>' . '<font size="2" color="blue"><strong>Price for rent: </strong></font>'. $dvdDetails->getDvdId()) . 
       '<br><br>' .
          '<div class="ghassar">' .
             '<div id="op"> <label>Number of days </label> <select name="days" > <option>1</option> <option>2</option> <option>3</option> <option>4</option> <option>5</option> 
     </select> 
     <br><br><br><br> 

     </div> 



     <div> 



     <input type="submit" value="Add to the basket" name="rent" id="buttom1" /> 
     </div> ' . '<br><br>' .
           '<br><br>' .'<div>'.

    '</td> </td> </tr>'; 
     } ?> 
     </tbody> 
    </table>
     <?php require('template/footer.phtml') ?>

//加入购物车

<?php
require_once('Models/Dvd_sql.php'); 
require_once('Models/Shop.php');  


$view = new stdClass(); 
$view->dd = 'SQL'; 
$dvd_sql = new Dvd_sql(); 
$view->dd  = $dvd_sql->fetchAllStudents();    //->fetchAllStudents(); 
if (isset($_POST['rent']))
{
    $tem = $_POST(['$dvdDetails->getDvdId()']);
 $shop = new Shop(); $shop->addProduct($tem);
}

   require_once('Views/dvdDetails.phtml');

最佳答案

我认为您想要做的是将 DVD 的 ID 从表单页面获取到表单处理页面。假设就是这样,那么您的处理方式存在一些问题。

  • 首先,$_POST['$dvdDetails->getDvdId()'] 在发布数据中查找与字符串“$dvdDetails->getDvdId()”字面匹配的字符串键。单引号中的字符串不会由 PHP 进行插值,即使使用双引号,您也确实想坚持使用简单变量和/或使用 {$brackets}
  • 其次,在我看来,对象 $dvdDetails 甚至不存在于表单处理脚本中。我只在表单显示代码中看到它,并且不会自动将其传输到处理脚本。您需要在表单中显式传递所需的数据。为此,您可以执行以下操作:

采用表单(遵循您的字符串连接样式)

'<input type="hidden" name="item_id" value="' . $dvdDetails->getDvdId() . '">' .

在处理脚本中

$item_id = $_POST['item_id'];

编辑
第一次时,我错过了您循环播放许多 DVD 项目的事实。在这种情况下,我的建议将导致许多 item_id 输入,并且处理脚本只会看到一个(我认为是最后一个)输入。您的“天”选择器也会遇到同样的问题。在这种情况下,我认为最简单的解决方案是为每张 DVD 创建单独的表格并使用我上面的建议。这样,当您提交特定 DVD 的表单时,只会发送一份“days”和“item_id”副本。

关于php - 获取用户选择的项目的 id?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21177093/

相关文章:

mysql - 将报表的结果查询作为参数传递给钻取报表

mysql - EntityManager 创建查询显示意外标记 :

html - 设置表格内文本的最大宽度 td

javascript - 如何在单击轮播的下一个或上一个按钮时停止滚动顶部?

php - 在 Laravel 4 中将尾部斜杠附加到 url

php - 在 php 电子邮件中以图像为中心的问题

html - 居中带有偏移量的截断文本 - 仅限 CSS

mysql - 此查询获取消息的最佳索引

php - 单个实体的 Doctrine2 自定义水化器

javascript - 在magento下订单成功后触发url