Diskuze: Řazení prvků ve víceúrovňových polích
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
array_multisort($products);
docela funguje.
Ale přiznám se, že sám teď pátrám proč.
No, ono to asi prostě tak dělá - řadí dle prvního sloupce.
Kdybys chtěl seřadit zase naopak dle ceny, je to složitější:
$arraySortPrice = array();
foreach ($products as $arrayEntry) {
$arraySortPrice[] = $arrayEntry["price"];
}
array_multisort($arraySortPrice, $products);
print_r($products);
Pokud něco říkám špatné, opravte mě.
Také se učím.
(hledal jsem - nejlíp vysvětleno mi to přišlo zde)
Da se pouzit i usort nebo uasort
php.net/usort
<?php
function cmp($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
foreach ($a as $key => $value) {
echo "$key: $value\n";
}
?>
Podminku si rozsiris na vsechny indexy, podle kterych chces serazovat. Napr
function cmp2(a,b) {
x = cmp(a[0],b[0]); if (x!=0) {return x;};
x = cmp(a[3],b[3]); if (x!=0) {return x;};
}
//usort($a, "cmp");
usort($a, "cmp2");
A také mi připadá nevhodné si znečišťovat si globální prostor tak
genericky pojmenovanou funkcí jako cmp
, lepší je IMHO udělat ji
anonymní, pokud se to hodí, a tady se to zrovna hodí.
$arr = array(3, 2, 5, 6, 1);
usort($arr, function ($a, $b) {
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
});
foreach ($arr as $key => $value) {
echo "$key: $value\n";
}
Anonymni funkce jsou zlo. Pokud to jde, vyhnout se. Souhlas, ze nazev cmp neni vhodny. Pouzil jsem copy-paste z php.net.
Rozveď, proč jsou anonymní funkce zlo. Samozřejmě je nechceš mít tak moc jako třeba v JS, ale např. jako argument funkce jsou perfektní.
My je v PHP používáme na registrování cron tasků, je to docela cool
Samozřejmě se dají ale
použít špatně místo obyčejných metod, lidé jsou schopní různých
věcí
Nevim, co ti k tomu rici. Proste, muj nazor, jsem hluboce presvedceny, ze je
to zlo
Kdyz je to funkce, melo by to byt napsane mezi funkcemi. Hur se pak v kodu
orientuje, ktera zavorka k cemu patri {}(); Jednoducha funkce, budiz, ale uz
jsem videl psat i mnohoradkove do nekolika malo radku natlacene prikazy do sebe
bez spolecne logiky
Nebo, kdyz treba tech usortu budes pouzivat 5, tak tam 5x pises celou
funkci?
Zobrazeno 10 zpráv z 10.