3

我正在尝试将我的程序代码转换为 oop。

 <?php
 $dbc = get_dbc();
 $info = mysqli_query($dbc, "SELECT info_id, info_title FROM text") or die("Error: ".mysqli_error($dbc));
 while ($info_row = mysqli_fetch_array($info))
 {
      $info_id = $info_row['info_id'];
      $info_title = $info_row['info_title'];
 ?>
 <div style="width: 100%;">
      <div style="float: left;">
           <?php echo $info_id; ?>
      </div>
      <div style="float: left;">
           <?php echo $info_title; ?>
      </div>
      <div style="clear: both;"></div>
 </div>
 <?php } ?>

我对没有 HTML 样式的类/对象的不完整尝试:

 <?php
 class InfoTest {

      private $info_id;
      private $info_title;

      public function __construct() {
           $dbc = get_dbc();
           $info = $dbc->query ("SELECT info_id, info_title FROM text");
           if ($dbc->error) {
                printf("Error: %s\n", $dbc->error);
           }       
           while ($info_row = $info->fetch_array())
           {
                $info_id = $info_row['info_id'];
                $info_title = $info_row['info_title'];  
           }
           $info->free();
           $this->info_id = $info_id;
           $this->info_title = $info_title; 
      }


      public function setInfoID() {
           $this->info_id = $info_id;
      }

      public function getInfoID() { 
           return $this->info_id;
      }

      public function setInfoTitle() {
           $this->info_title = $info_title;
      }

      public function getInfoTitle() {
           return $this->info_title;
      }

      public function __destruct() {    
      }

 }

 ?>
 <?php
 $display = new InfoTest();
 echo $display->getInfoID();
 echo $display->getInfoTitle();
 ?>

我的程序代码打印出来:1 一 2 二。

我的 oop 代码打印出来:2 两个

据我了解,oop 以这种方式打印出来,因为 $info_id 和 $info_title 不是数组,并且只打印出最后存储的信息。

所以,如果我改变:

$info_id = $info_row['info_id'];
$info_title = $info_row['info_title'];

至:

$info_id[] = $info_row['info_id'];
$info_title[] = $info_row['info_title'];

并打印数组,它显示了我想要的所有信息,但是如何以非数组形式显示呢?

到目前为止我正在做的事情是正确的还是我正在接近这个错误?

4

3 回答 3

0

因为 info id 是对象中的数组,所以获取值的相应函数应该采用偏移量。或者更好的是,您应该查看实现迭代器的类,以便您可以对对象执行 foreach

于 2011-08-16T02:07:12.007 回答
0

你这样做是错的。在您的程序示例中,您一次遍历一行数据;在您的 OO 示例中,如果您将它们视为数组然后打印它们,那么您将一次浏览一列数据。我不会将数据分成单独的 id 和标题,而是将它们视为一个包(即类似于您在程序版本中的做法)- id 与标题一起使用,而不是其他 id,对吗?

因此,例如,您可能有一个成员变量

private $texts = array();

然后在您的构造函数中,执行:

while ($info_row = $info->fetch_array()) {
    $text = array(
        'id' => $info_row['info_id'],
        'title' => $info_row['info_title']
    );
    $this->texts[] = $text;
}

然后提供一种方法来获取这个数组数组:

public function getTexts() {
    return $this->texts;
}

最后,您可以非常类似于在程序示例中的方式对其进行迭代:

<?php
$display = new InfoTest();
foreach ($display->getTexts() as $text) {
    ?>
    <!-- html goes here -->
    <?php echo $text['info_id']; ?>
    <!-- more html -->
    <?php echo $text['info_title']; ?>
    <!-- other html -->
    <?
}
?>

退后一步——你可以问这一切是否真的有必要。程序式 PHP 本身并没有什么问题——如果它完成了你需要它做的事情并且做得很清楚,那么在这里你最好选择简单而不是复杂。

于 2011-08-16T02:15:36.903 回答
0

在切换到 OOP 之前,我首先将代码模块化并开始分割成相互分离逻辑的功能部分,例如数据库访问和模板:

<?php

/**
 * infos provider
 *
 * @return array
 */
function get_infos()
{
    $infos = array();
    $dbc = get_dbc();
    $info = mysqli_query($dbc, "SELECT info_id, info_title FROM text") or die("Error: ".mysqli_error($dbc));
    while ($info_row = mysqli_fetch_array($info))
    {
        $infos[] = (object) $info_row;
    }
    return $infos;
}

foreach(get_infos() as $info)
{
?>
<div style="width: 100%;">
     <div style="float: left;">
          <?php echo $info->info_id; ?>
     </div>
     <div style="float: left;">
          <?php echo $info->info_title; ?>
     </div>
     <div style="clear: both;"></div>
</div>
<?php } ?>

然后将与数据库相关的功能移动到它自己的文件中,以将其与“模板”分离。完成后,您可以考虑进一步的重构步骤。我建议阅读以下内容(仅独立于命名框架):当平面 PHP 遇到 symfony 时

于 2011-08-16T02:19:28.930 回答