PHP « Построение таблицы сравнения товаров
Доброго времени суток.
Пытаюсь сделать таблицу сравнения товаров. В целом, в теории сложного ничего не было. Но вот когда дошел до реализации, то вылез коварный "подводный камень" для меня.
С такими вещами я пока на "ВЫ", ибо не могу правильно написать.
Сразу приведу, что хочу получить в результате http://s40.radikal.ru/i087/1209/1f/a2a83ef0fea8.gif
То есть те значения, которые отсутствуют заменять на --- или на что угодно.
В процессе выборки (код приведу ниже) формируется такой массив.
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
Array
(
[0] => Array
(
[id] => 33
[name] => Apple MacBook MB403
[price] => 15.000,0 руб.
[extra] => Array
(
[Процессор] => Core 2 Duo 2400 МГц
[Память] => 2048 Мб DDR2 667 МГц
[Дисплей] => 13.3 дюймов, 1280x800
[Графический чипсет] => Intel GMA X3100
)
)
[1] => Array
(
[id] => 32
[name] => Apple MacBook MB402
[price] => 15.000,0 руб.
[extra] => Array
(
[Процессор] => Core 2 Duo 2100 МГц
[Память] => 1024 Мб DDR2 667 МГц
[Дисплей] => 13.3 дюймов, 1280x800
)
)
[2] => Array
(
[id] => 31
[name] => Apple MacBook Air
[price] => 15.000,0 руб.
[extra] => Array
(
[Память] => 2048 Мб
[Жесткий диск] => 64...80 Гб
[Аккумулятор] => Li-Pol
)
)
)
extra - это эти самые параметры. Как видно, все они почти разные у товаров. Выборка из БД жесткая, именно в таком варианте. Так как выбираются ТОЛЬКО заполненные параметры. Т.е. у товара 33 никак нет параметра "Аккумулятор" и проверить его на пустоту не получается, чтобы заменить на ---.
По этому, нужно (как я думаю) объединить названия параметров в массив, убрать повторы, а потом по ним уже сверять сами параметры. Вот тут и проблема - не знаю как правильно это сделать.
Это PHP который все сейчас делает.
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
// Запрос на товары
$pq = $product->getProductsCompare();
$list = array();
while($p = mysql_fetch_array($pq))
{
// Запрос на выборку параметров
$eq = $product->getProductsExtra($p['id']);
$extra = array();
while ($ef = mysql_fetch_array($eq))
{
$extra[$ef['name']] = $ef['param'];
}
$list[] = array
(
'id' => $p['id'],
'name' => $p['name'],
'price' => $p['price'],
'extra' => $extra, // параметры в общий массив
);
}
$list - отдаю в шаблон с помощью Smarty
Сколько бьюсь, никак не получается.
Пытаюсь сделать таблицу сравнения товаров. В целом, в теории сложного ничего не было. Но вот когда дошел до реализации, то вылез коварный "подводный камень" для меня.
С такими вещами я пока на "ВЫ", ибо не могу правильно написать.
Сразу приведу, что хочу получить в результате http://s40.radikal.ru/i087/1209/1f/a2a83ef0fea8.gif
То есть те значения, которые отсутствуют заменять на --- или на что угодно.
В процессе выборки (код приведу ниже) формируется такой массив.
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
Array
(
[0] => Array
(
[id] => 33
[name] => Apple MacBook MB403
[price] => 15.000,0 руб.
[extra] => Array
(
[Процессор] => Core 2 Duo 2400 МГц
[Память] => 2048 Мб DDR2 667 МГц
[Дисплей] => 13.3 дюймов, 1280x800
[Графический чипсет] => Intel GMA X3100
)
)
[1] => Array
(
[id] => 32
[name] => Apple MacBook MB402
[price] => 15.000,0 руб.
[extra] => Array
(
[Процессор] => Core 2 Duo 2100 МГц
[Память] => 1024 Мб DDR2 667 МГц
[Дисплей] => 13.3 дюймов, 1280x800
)
)
[2] => Array
(
[id] => 31
[name] => Apple MacBook Air
[price] => 15.000,0 руб.
[extra] => Array
(
[Память] => 2048 Мб
[Жесткий диск] => 64...80 Гб
[Аккумулятор] => Li-Pol
)
)
)
extra - это эти самые параметры. Как видно, все они почти разные у товаров. Выборка из БД жесткая, именно в таком варианте. Так как выбираются ТОЛЬКО заполненные параметры. Т.е. у товара 33 никак нет параметра "Аккумулятор" и проверить его на пустоту не получается, чтобы заменить на ---.
По этому, нужно (как я думаю) объединить названия параметров в массив, убрать повторы, а потом по ним уже сверять сами параметры. Вот тут и проблема - не знаю как правильно это сделать.
Это PHP который все сейчас делает.
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
// Запрос на товары
$pq = $product->getProductsCompare();
$list = array();
while($p = mysql_fetch_array($pq))
{
// Запрос на выборку параметров
$eq = $product->getProductsExtra($p['id']);
$extra = array();
while ($ef = mysql_fetch_array($eq))
{
$extra[$ef['name']] = $ef['param'];
}
$list[] = array
(
'id' => $p['id'],
'name' => $p['name'],
'price' => $p['price'],
'extra' => $extra, // параметры в общий массив
);
}
$list - отдаю в шаблон с помощью Smarty
Сколько бьюсь, никак не получается.
1 ответов
// Запрос на товары
$pq = $product->getProductsCompare();
$list = array();
// массив с названиями параметров
$paramNames = array();
while($p = mysql_fetch_array($pq))
{
// Запрос на выборку параметров
$eq = $product->getProductsExtra($p['id']);
$extra = array();
while ($ef = mysql_fetch_array($eq))
{
$extra[$ef['name']] = $ef['param'];
// наполняем список имен параметров
if(!in_array($ef['name'], $paramNames))
$paramNames[] = $ef['name'];
}
$list[] = array
(
'id' => $p['id'],
'name' => $p['name'],
'price' => $p['price'],
'extra' => $extra, // параметры в общий массив
);
}
// проходмим по списку товаров и добавляем недостающие параметры
foreach($list as &$item) {
foreach($paramNames as $name)
if (!array_key_exists($name ,$item['extra'])) {
$item['extra'][$name] = '--';
}
}
Примерно вот так
function test() {
$items = Array
(
Array
(
'id' => 33,
'name' => 'Apple MacBook MB403',
'price' => ' 15.000,0 руб.',
'extra' => Array
(
'Процессор' => array('val'=>'Core 2 Duo 2400 МГц','order' => 1),
'Память' => array('val'=>'2048 Мб DDR2 667 МГц','order' => 3),
'Дисплей' => array('val'=>'13.3 дюймов, 1280x800','order' => 2),
'Графический чипсет' => array('val'=>'Intel GMA X3100','order' => 4),
)
),
Array
(
'id' => 32,
'name' => 'Apple MacBook MB402',
'price' => '15.000,0 руб.',
'extra' => Array
(
'Процессор' => array('val'=>'Core 2 Duo 2100 МГц','order' => 1),
'Память' => array('val'=>'1024 Мб DDR2 667 МГц','order' => 3),
'Дисплей' => array('val'=>'13.3 дюймов, 1280x800','order' => 2),
)
),
Array
(
'id' => 31,
'name' => 'Apple MacBook Air',
'price' => '15.000,0 руб.',
'extra' => Array
(
'Память' => array('val'=>'2048 Мб','order' => 3),
'Жесткий диск' => array('val'=>'64...80 Гб','order' => 5),
'Аккумулятор' => array('val'=>'Li-Pol','order' => 6),
)
)
);
$paramNames = array();
$orers = array();
foreach ($items as $item) {
foreach($item['extra'] as $name => $value)
if(!in_array($name, $paramNames)) {
$paramNames[] = $name;
$orders[] = $value['order'];
}
}
foreach($items as &$item) {
foreach($paramNames as $k=>$name) {
if (!array_key_exists($name ,$item['extra'])) {
$item['extra'][$name] = array('val'=>'--','order'=>$orders[$k]);
}
}
uasort($item['extra'], 'sorting');
}
}
function sorting($a, $b) {
if ($a['order'] == $b['order'])
return 0;
return ($a['order'] < $b['order']) ? -1 : 1;
}