PHP程序到OOP

时间:2011-08-16 01:58:17

标签: php html oop procedural

我正在尝试将我的程序代码转换为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 One 2 Two。

我的oop代码打印出来:2 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'];

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

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

3 个答案:

答案 0 :(得分:0)

因为info id是对象中的数组,所以获取值的相应函数应该采用偏移量。或者甚至更好的是你应该看看你的类实现迭代器,这样你就可以对你的对象进行预测

答案 1 :(得分: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没有任何本质上的错误 - 如果它完成了你需要它做的事情而且做得很清楚,你可能最好更喜欢简单过于复杂的。

答案 2 :(得分: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 } ?>

然后将数据库相关的函数移动到它自己的文件中,以将其与“模板”分离。完成后,您可以考虑进一步的重构步骤。我建议以下阅读(仅与指定的框架无关):When flat PHP meets symfony