1

データベースに追加されたすべての属性のリストを表示したいのですが、何かを試すたびに機能しません。これをフロントページからのdiv内に表示したいと思います。私はこれをfeatured.tplに挿入しようとしました:

<?php 
foreach ($attribute_groups as $attribute_group) {
echo $attribute_group['name'];
print_r($attribute_group);
echo '<select name="listaGrupe">';
foreach ($attribute_groups['attribute'] as $attribute) {
echo '<option value="'.$attribute.'">'.$attribute.'</option>';
}
echo '</select>';
}

?>
4

3 に答える 3

1

このモデルを使用する必要があります

public function getAttributes($data = array()) {
    $sql = "SELECT *, (SELECT agd.name FROM " . DB_PREFIX . "attribute_group_description agd WHERE agd.attribute_group_id = a.attribute_group_id AND agd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS attribute_group FROM " . DB_PREFIX . "attribute a LEFT JOIN " . DB_PREFIX . "attribute_description ad ON (a.attribute_id = ad.attribute_id) WHERE ad.language_id = '" . (int)$this->config->get('config_language_id') . "'";

    if (!empty($data['filter_name'])) {
        $sql .= " AND LCASE(ad.name) LIKE '" . $this->db->escape(utf8_strtolower($data['filter_name'])) . "%'";
    }

    if (!empty($data['filter_attribute_group_id'])) {
        $sql .= " AND a.attribute_group_id = '" . $this->db->escape($data['filter_attribute_group_id']) . "'";
    }

    $sort_data = array(
        'ad.name',
        'attribute_group',
        'a.sort_order'
    );  

    if (isset($data['sort']) && in_array($data['sort'], $sort_data)) {
        $sql .= " ORDER BY " . $data['sort'];   
    } else {
        $sql .= " ORDER BY attribute_group, ad.name";   
    }   

    if (isset($data['order']) && ($data['order'] == 'DESC')) {
        $sql .= " DESC";
    } else {
        $sql .= " ASC";
    }

    if (isset($data['start']) || isset($data['limit'])) {
        if ($data['start'] < 0) {
            $data['start'] = 0;
        }               

        if ($data['limit'] < 1) {
            $data['limit'] = 20;
        }   

        $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit'];
    }   

    $query = $this->db->query($sql);

    return $query->rows;
}

コントローラ内のは、このモデルをロードし、返されたデータで操作するだけです。デフォルトでは、データベース内のすべての属性を返します

于 2012-12-18T05:01:38.667 に答える
0

これに近い関数形式を探している可能性があります。

foreach ($attribute_groups as $attribute_group) {
$options = '';
$name = $attribute_group['name'];
$output = '<select name="$name">';
foreach ($attribute_groups['attribute'] as $attribute) {
$options .= '<option value="'.$attribute.'">'.$attribute.'</option>';
}
echo $output.$options.'</select>';
}
于 2012-09-24T13:55:05.667 に答える
0

コントローラをチェックインします..$attribute_groupsにデータが含まれているかどうか...

print_r($ attribute_groups);

$attribute_groups配列が空でないことを確認してください...$attribute_groups配列が空であるため、このエラーが発生すると思います...

確かな場合は、$ attribute_groupsを空にすることができ、次にチェックできます...

if(!empty($attribute_groups)){
foreach ($attribute_groups as $attribute_group) {
$options = '';
$name = $attribute_group['name'];
$output = '<select name="$name">';
foreach ($attribute_groups['attribute'] as $attribute) {
$options .= '<option value="'.$attribute.'">'.$attribute.'</option>';
}
echo $output.$options.'</select>';
}
}

これにより、配列が空かどうかがわかります。空でない場合は、foreach()...それ以外の場合は何もしません。

于 2012-09-24T14:19:28.063 に答える