0

这是一个运输模块,可让您选择分店进行本地取货。分支列在 csv 中,而不是在数据库中。

<?php
        if ( ($n > 1) || ($n2 > 1) ) {
         if ($quotes[$i]['id'] == 'localdelivery') {
          if (file_exists($quotes[$i]['pricesL'])) {
           echo '<td class="main" style="padding-right:15px;"><select name="locdeliv">';
           $file_handle = fopen($quotes[$i]['pricesL'], "r");
           while (!feof($file_handle)) {
            $line_of_text = fgetcsv($file_handle, 1024);
            echo '<option value="' . $line_of_text[1] . '">' . $line_of_text[0] . '</option>';
                                       }
            fclose($file_handle);
                                                     }
          else {
           echo '<td class="main"><select name="locdeliv"><option value="0">file missing</option>';
               }
          echo '</select></td>';
                                                }
         //else {
?>

这很好用。以下代码显示了用户所看到的运输描述:

    function quote($method = '') {
  global $order;

  $this->quotes = array('id' => $this->code,
                        'module' => MODULE_SHIPPING_LOCALDELIVERY_TEXT_TITLE,
                        'pricesL' => MODULE_SHIPPING_LOCALDELIVERY_PRICESFILE,
                        'methods' => array(array('id' => $this->code,
                                                 'title' => print $line_of_text[1],
                                                 'cost' => MODULE_SHIPPING_LOCALDELIVERY_COST)));

  if ($this->tax_class > 0) {
    $this->quotes['tax'] = tep_get_tax_rate($this->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
  }

  if (tep_not_null($this->icon)) $this->quotes['icon'] = tep_image($this->icon, $this->title);

  return $this->quotes;
}

这部分

'title' => print $line_of_text[1],

我需要回应用户从下拉列表中选择的任何内容。我尝试了各种方法,例如 $file_handle 等,但结果总是得到“1”。有没有一种简单的方法可以将选定的下拉值放入“标题”?这允许稍后将标题保存在数据库中。在其他模块中,“标题”取自语言文件,因此它永远不会来自数据库,结帐页面“不在乎”该行是什么,它将其保存到数据库中,以便我可以看到选择了哪个选项在行政上。使用 CSV 的原因是公司经常更新分支机构,这是经常更新的最简单方法。

4

1 回答 1

0

您在定义变量时尝试使用programming construct( ) - 这是不正确的语法。print

您需要做的是使用函数 ,Quote并从返回的数组中获取值。

$result = $obj->quote();
$title  = $result['methods'][0]['title'];
print $title;

编辑详细说明:

您的函数quote正在引用$this,这意味着它是 a methodwithin a class。为了能够使用此方法,您需要在类本身之外调用它。我们称之为客户端代码。

class Foo
{
  public function quotes() {
    // ** all your code **
    return $this->quotes;
  }
}

// outside the class, so client code
$foo = new Foo();
$result = $foo->quote();
$title  = $result['methods'][0]['title'];
print $title;
于 2013-05-03T00:48:52.093 回答