abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 18:11 | IT novinky

    Dnes a zítra probíhá vývojářská konference Google I/O 2025. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Komunita

    V Bostonu probíhá konference Red Hat Summit 2025. Vybrané přednášky lze sledovat na YouTube. Dění lze sledovat na síti 𝕏 (#RHSummit).

    Ladislav Hagara | Komentářů: 0
    včera 15:00 | Nová verze

    Společnost Red Hat oficiálně oznámila vydání Red Hat Enterprise Linuxu 10. Vedle nových vlastností přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Podrobnosti v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    včera 12:22 | Pozvánky

    Tuto sobotu 24. května se koná historicky první komunitní den projektu Home Assistant. Zváni jsou všichni příznivci, nadšenci a uživatelé tohoto projektu. Pro účast je potřebná registrace. Odkazy na akce v Praze a v Bratislavě.

    jose17 | Komentářů: 0
    včera 04:44 | IT novinky

    Troy Hunt představil Have I Been Pwned 2.0, tj. nový vylepšený web služby, kde si uživatelé mohou zkontrolovat, zda se jejich hesla a osobní údaje neobjevily v únicích dat a případně se nechat na další úniky upozorňovat.

    Ladislav Hagara | Komentářů: 14
    19.5. 23:22 | Zajímavý software

    Microsoft představil open source textový editor Edit bežící v terminálu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

    Ladislav Hagara | Komentářů: 7
    19.5. 22:22 | Zajímavý software

    V Seattlu a také online probíhá konference Microsoft Build 2025. Microsoft představuje své novinky. Windows Subsystem for Linux je nově open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.

    Ladislav Hagara | Komentářů: 0
    19.5. 13:11 | Zajímavý článek

    Z příspěvku Turris Sentinel – co přinesl rok 2024 na blogu CZ.NIC: "Za poslední rok (únor 2024 – únor 2025) jsme zachytili 8,3 miliardy incidentů a to z 232 zemí a z jejich závislých území. Tyto útoky přišly od 6,2 milionu útočníků (respektive unikátních adres). SMTP minipot je stále nejlákavější pastí, zhruba 79 % útoků bylo směřováno na tento minipot, 16 % útoků směřovalo na minipot Telnet, 3 % útoků směřovaly na minipot HTTP a 2 % na minipot FTP. Dále jsme zaznamenali 3,2 milionu unikátních hesel a 318 tisíc unikátních loginů, které útočníci zkoušeli."

    Ladislav Hagara | Komentářů: 1
    19.5. 12:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) nová verze 3.0.4 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    19.5. 12:33 | Nová verze

    Byla vydána nová stabilní verze 7.4 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 136. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (60%)
     (23%)
     (9%)
     (2%)
     (0%)
     (0%)
     (6%)
    Celkem 47 hlasů
     Komentářů: 5, poslední včera 20:57
    Rozcestník

    php menu

    11.1.2007 12:41 | Přečteno: 4513× | Programování

    Zrovna se učím php na jednom projektu pro kamaráda(bude se jednat o ovládací panel na wi-fi router, protože on je totální BFU a webmin se mi nezamlouvá) a právě se mi podařilo dokončit algoritmus na vykreslení stromového menu a protože se na tom to PHP učím tak bych se chtěl zeptat, jestli by se na následujícím kódu dalo ještě něco upravit, nebo optimalizovat(jinak kdyby se tento kód někomi zalíbil, tak si jej klidně může použít;-)):

    function showmenu() {
    	$sql= "SELECT * FROM menu ORDER BY position, menu_id";
    	$menu= dbcon($sql);
    	$sqlm= "SELECT MAX(level) AS level from menu";
    	$rowsm= dbcon(($sqlm));
    	$rows= array ();
    	//Pole pro uchovávání indexů, kde jsme v předchozí úrovní menu zkončili
    	$oldn= array ();
    	for ($i= 0; $i lt; count($menu); $i ++) {
    		if ($menu[$i]["level"] == '0') {
    			array_push($rows, $menu[$i]);
    		}
    	}
    	echo "<table>\n";
    	menu_rec(0, $rowsm[0]["level"], $rows, 0, $oldn, $menu);
    	echo "</table>\n";
    }
    
    function menu_rec($level, $maxlevel, $rowd, $next, $oldn, $menu) {
    	if ($level <= $maxlevel) {
    		if (isset ($rowd[$next]) && $rowd[$next]["level"] == $level) {
    			echo "<tr><td>";
    			for ($i= 0; $i < $level; $i ++) {
    				echo "*";
    			}
    			echo "<a href=\"index.php?".$rowd[$next]["url"]."\">".$rowd[$next]["title"]."</td></tr>\n";
    		}
    		$rowdo= $rowd;
    		$rowd= array ();
    		for ($i= 0; $i < count($menu); $i ++) {
    			if ($menu[$i]["parent"] == $rowdo[$next]["menu_id"]) {
    				array_push($rowd, $menu[$i]);
    			}
    		}
    		//Pokud existuje potomek, pokračuj zde.
    		if (isset ($rowd[0])) {
    			// a ulož kde jsme zkončili
    			array_push($oldn, $next);
    			menu_rec(++ $level, $maxlevel, $rowd, 0, $oldn, $menu);
    		}
    		//Jinak jdi na následující položku v řadě
    		elseif (isset ($rowdo[++ $next])) {
    			menu_rec($level, $maxlevel, $rowdo, $next, $oldn, $menu);
    		}
    		//Pokud neexistuje dálší v řadě(next je inkrementováno z předchozího elseif) a neexistije potomek, jdi zpět nahoru
    		elseif ((!(isset ($rowdo[$next]))) && (!(isset ($rowd[0])))) {
    			$row= array ();
    			//Sniž hodnotu next, protože je zvýšená od elseif
    			-- $next;
    			//Získej předka aktuální položky
    			for ($i=0; $i < count($menu); $i ++) {
    				if ($menu[$i]["menu_id"] == $rowdo[$next]["parent"]) {
    					array_push($row, $menu[$i]);
    				}
    			}
    			//Pokud existuje předek pokračuj
    			if (isset ($row[0])) {
    				$rows= array ();
    				// a získej přechozí úroveň menu
    				for ($i=0; $i < count($menu); $i ++) {
    					if ($menu[$i]["parent"] == $row[0]["parent"]) {
    						array_push($rows, $menu[$i]);
    					}
    				}
    			// Jinak menu ukonči
    			} else {
    				return;
    			}
    			//Zjisti, kde jsme v přechozí úrovni zkončili
    			$next= array_pop($oldn);
    			//Dokud neexistuje další položka v předcozí úrovni jdi nahoru
    			while (!(isset ($rows[$next +1]))) {
    				$row= array ();
    				// a získej  předka v předchozí úrovni
    				for ($i= 0; $i < count($menu); $i ++) {
    					if ($menu[$i]["menu_id"] == $rows[$next]["parent"]) {
    						array_push($row, $menu[$i]);
    					}
    				}
    				$rows= array ();
    				// Získej předchozí úroveň
    				for ($i= 0; $i < count($menu); $i ++) {
    					if ($menu[$i]["parent"] == $row[0]["parent"]) {
    						array_push($rows, $menu[$i]);
    					}
    				}
    				// a zjisti, kde jsme v ní zkončili
    				$next= array_pop($oldn);
    				//odečti čislo úrovně
    				-- $level;
    			}
    			menu_rec(-- $level, $maxlevel, $rows, ++ $next, $oldn, $menu);
    		}
    	}
    }
    

    Celé menu volám ze stránky pomocí funkce showmenu()

    Menu je pak uloženo v takové tabulce:
    mysql> SELECT * FROM menu;
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    | title         | url                                            | type    | menu_id | position | parent | level |
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    | Návody       | com=article&task=lists&cat=2           | article |      16 |        2 |      0 |     0 |
    | test          | com=article&task=listp&cat=1&cat=6 | article |      15 |        1 |      0 |     0 |
    | UpozornÄí\ | com=article&task=listp&cat=1           | article |      12 |        0 |      0 |     0 |
    | test1         | com=article&task=listp&cat=1           | article |      21 |        0 |     15 |     1 |
    | test3         | com=article&task=listp&cat=2           | article |      22 |        0 |     21 |     2 |
    | ahoj          | com=article&task=listp&cat=6           | article |      23 |        0 |      0 |     0 |
    | ahoj2         | com=article&task=listp&cat=6           | article |      24 |        0 |     23 |     1 |
    | ahoj3         | com=article&task=listp&cat=2           | article |      25 |        0 |     23 |     1 |
    | ahoj4         | com=article&task=lists&cat=2           | article |      26 |        0 |     25 |     2 |
    | ahoj5         | com=article&task=listp&cat=6           | article |      27 |        0 |     24 |     2 |
    | ahoj6         | com=article&task=listp&cat=2           | article |      28 |        0 |     23 |     1 |
    | test5         | com=article&task=listp&cat=1&cat=6 | article |      32 |        1 |     22 |     3 |
    | test4         | com=article&task=listp&cat=1&cat=6 | article |      31 |        0 |     22 |     3 |
    +---------------+------------------------------------------------+---------+---------+----------+--------+-------+
    
           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    xxx avatar 11.1.2007 13:13 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    V php se nevyznam, ale v ty db mas redundanci. Ve sloupci url mas com=article, pricemz tam mas pak jeste sloupec type.
    Please rise for the Futurama theme song.
    11.1.2007 13:43 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Mám to tam proto, abych v jiné částí kódu nemusel parsovat to url, kvůli zjištění typu komponenty.
    xxx avatar 11.1.2007 13:58 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    Ale to url, lze cele sestavit z tech ostatnich sloupcu.
    Please rise for the Futurama theme song.
    xxx avatar 11.1.2007 14:08 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: php menu
    Teda ne uplne cele, ale cast. Tudiz jsem to myslel tak, ze by ten dotaz mel byt spise SELECT CONCAT('com=',CONCAT(type,zbytekurl)) FROM tabulka. (Nevim jak presne se ty sloupce a tabulka jmenuji). Protoze si predstav, ze zmenis typ nektere polozky.
    Please rise for the Futurama theme song.
    11.1.2007 14:30 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: php menu
    select 'com=' || type || zbytekurl from tabulka

    btw, v tom prípade by mal celú url skladať zo dát (a pridať stĺpce)
    11.1.2007 13:45 Lu-Tze | skóre: 15 | blog: Lu-Tzeho blog
    Rozbalit Rozbalit vše Re: php menu
    Spíš se mi zdá, že je tam zbytečná položka level.
    11.1.2007 18:57 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: php menu
    Proč sis vytvořil nový profil?
    11.1.2007 19:02 Lu-Tze | skóre: 15 | blog: Lu-Tzeho blog
    Rozbalit Rozbalit vše Re: php menu
    Protože jsem blázen. Na druhou stranu si to uvědomuju, takže možná blázen nejsem. Asi jenom chvilkama.
    11.1.2007 19:19 Käyttäjä 11133 | skóre: 58 | blog: Ajattelee menneisyyttä
    Rozbalit Rozbalit vše Re: php menu
    Hmm zrovna tebe jsem za blázna nikdy nepovažoval, ale co se dá dělat. :-) Kdyby si chtěl pokecat napiš na jabber. ;-)
    12.1.2007 11:36 Aleš Kapica | skóre: 52 | blog: kenyho_stesky | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Musím říct že mě od tebe nic tak nepobavilo jako tohle. Fakt to cením.
    11.1.2007 17:02 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    Myslim, ze celej ten sloupec s URL je takovej divnej a zbytecnej. Co takhle ukladat ten typ, cislo clanku a popripade dalsi veci ze kterych se bude skladat url, kazdou informaci do jednoho sloupce. URL pak z toho jednoduse poskladas.

    Jo a btw, zajimalo by me co sledujes napriklad tim com=article&task=listp&cat=1&cat=6. Promenna cat bude mit ve vysledku stejne hodnotu 6. Pokud by si to chtel cpat do pole, tak by si to musel oznacit v url jako cat[].
    11.1.2007 17:17 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S tím jsem si pohrál a neberu tu url přes $_GET["cat"], ale přes $_SERVER["REQUEST_URI"] a to pársuju pomocí tohoto kódu:
    case "lists" :
    		$url= clean($_SERVER["REQUEST_URI"]);
    		$url= ereg_replace("(.*)(\?)", "", $url);
    		$cats= array ();
    		$cats= split("&", $url);
    		$sql= "SELECT cat_id FROM category";
    		$rows= dbcon($sql);
    		foreach ($rows as $row) {
    			if (in_array("cat=".$row["cat_id"], $cats)) {
    				$sql1= "SELECT con_id, title, pretxt FROM content WHERE state='1' AND cat_id=\"".$row["cat_id"]."\" ORDER BY con_id DESC";
    				$rows1= dbcon($sql1);
    				foreach ($rows1 as $row1) {
    					echo "<h4><a href=\"index.php?com=article&task=view&id=".$row1["con_id"]."\">".$row1["title"]."</a></h4>";
    				}
    			}
    		}
    		break;
    
    Pokud by si to chtel cpat do pole, tak by si to musel oznacit v url jako cat[].
    To by mě docela zajímalo jak, abych to nemusel řešit tím složitým procházením URL, protože jak dát do url a do databáze PHP pole, na to jsem ještě nepřišel.
    11.1.2007 21:20 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    To je prasarna ;-).

    Co jak? Kdyz zadas v URL neco jako index.php?test[]=a&test[]=b, tak ti v php vznikne pole $test = array('a', b'). Proc to cpat do databaze nechapu, ale pole tam nacpes napriklad pres funkci serialize.

    Jo a neodpovedel jsi proc cpes do DB tu celou URL a ne jen ty casti jak jsem napsal? Tohle je fakt hrozny a do budoucna spatne pouzitelny.
    11.1.2007 22:30 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S tou celou url v DB jsem se inspiroval u Joomly, ve které mám svoje stránky. ;-)

    A k poli v DB, to znamená, že pro veřejnou část, kde to mám v URL jako test[]=a&test[]=b jsem to teda vyřešil přes $_GET["test"].

    Ale jak v admin části, abych to pole nemusel pársovat čísla kategorií jako v příspěvku výše?

    Mám použít (un)serialize, nebo existuje nějaká možnost jak ze zápisu test[]=a&test[]=b zpětně zrekonstruovat pole?
    12.1.2007 17:23 Goffix | skóre: 25 | blog: Powered by ArchLinux | Hradec Králové
    Rozbalit Rozbalit vše Re: php menu
    Ja vubec nevim vo cem to tu tocis :-)

    Ja myslel, ze kdyz zacinas, tak chces rady? To, ze jsi se inspiroval v nejake jine aplikaci neznamena, ze je to nejlepsi postup. Furt nechapu co se snazis cpat za blbosti do DB. Kdyby si to udelal, jak jsem psal ja i jini vyse, tak muzes nejaky parsovani vyhodit a mas hned zivot jedndussi ;-).
    11.1.2007 14:39 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: php menu
    >nešlo by to zjednodušiť? napr niečo ako:
                      
    function showmenu () {
        $sql= "SELECT * FROM menu ORDER BY parent, position, menu_id";
        $menu = dbcon($sql);
    
        $menu_def = array (0 => array ('-children' => array ()));
    
        foreach ($menu as $row) {
            $menu_def[ $row['menu_id'] ] = $row;
            if (! array_key_exists ('-children', $menu_def[ $row['parent'] ]))
                $menu_def[ $row['parent'] ]['-children'] = array ();
            array_push ($menu_def[ $row['parent'] ]['-children'], $row['menu_id']);
        }
    
        echo '<table>';
        menu_rec ($menu_def, 0);
        echo '</table>';
    }
    
    function menu_rec ($menu_def, $id) {
        $entry = $menu_def[ $id ];
    
        if (array_key_exists ('title', $entry)) {
            echo '<tr><td>';
            echo '<a href="index.php?' . $entry['url'] . '">' . $entry['title'] . '</a>';
            echo '</td></tr>';
            echo "\n";
        }
    
        if (array_key_exists ('-children', $entry)) {
            foreach ($entry['-children'] as $next_id) {
                menu_rec ($menu_def, $next_id);
            }
        }
    }
    
    php nemám, ani mať nebudem, možno som ani pôvodné zadanie správne neprelúštil
    btw, tabuľky? fuj
    11.1.2007 19:22 12345 | skóre: 41 | blog:
    Rozbalit Rozbalit vše Re: php menu
    Drobná poznámka – zbytečně používáš double quoted řetězce na místech, kde je vůbec není nutné parsovat (indexy polí, SQL,…). Viz http://www.php.net/manual/en/language.types.string.php.
    11.1.2007 19:24 12345 | skóre: 41 | blog:
    Rozbalit Rozbalit vše Re: php menu
    A ještě rýpnutí – skončili ;-)
    Daniel Kvasnička ml. avatar 11.1.2007 22:26 Daniel Kvasnička ml. | skóre: 52 | blog: The Joys and Sorrows of Being an IT Freak | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    Uz jsem tady i jinde videl par uchylnych pripadu pouziti databaze, ale co je moc, to je moc. Tohle je snad ten nejtypictejsi pripad pro pouziti XML sitemapy a renderovani menu pomoci XSLT. Nechapu k cemu takovahle monstrozni konstrukce...
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    11.1.2007 22:38 filbar | skóre: 36 | blog: Denicek_programatora | Ostrava
    Rozbalit Rozbalit vše Re: php menu
    S programováním PHP+SQL teprve začínám (toto je moje první větší aplikaceú a co se týče mých informací o PHP, tak ty pocházejí z PHP a MySQL:Vytváříme webové databázové aplikace od O'REILLY a Computer Pressu a tady toto programuji, abych se v PHP naučil dělat.;-)

    Kde bych teda mohl ty informace o XML sitemapách a renderování pomocí XSLT mohl najít? Stačí jenom nějaký link na nasměrování. A šlo by to použít i pro diskusní fórum s thready(které si taky chci vyzkoušet udělat)? Protože jsem tuto "monstrózní" konstrukci použil, že se bude hodit i pro fórum.
    No bud si muzes vytvorit svuj XML format pro sitemapu nebo pouzit (resp. rozsirit) oficialni XML Sitemaps protokol od Google, MS a Yahoo (ktery bys stejne pouzivat mel -- tedy pro prezentace, ktere chces, aby Google bral na vedomi). Nicmene ten googli neni tak uplne delany na generovani menu -- osobne ho pouzivam jen pro google.

    O zadnem konkretnim clanku konkretne o renderovani XML sitemap pomoci XSLT nevim, ale pres Google urcite najdes tuny dobrych tutorialu o XSLT (obecne moc dobry server na veci kolem XML je Zvon.org a tamni paradni XSLT reference). Zasadni vyhoda XML v tomto pripade je schopnost zaznamenat tu hierarchicnost (to co ty zaznamenavas polem "parent").
    FSF: “screw you for not wanting the stuff we produce”, People: “screw you for not producing the stuff we want."
    Josef Kufner avatar 13.1.2007 15:39 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: php menu
    Pak se nabízí ještě jedna značně primitivní, ale pravděpodobně naprosto dostačující možnost:
    $main_menu = array (
       'neco.php?bla+bla' => 'Nadpis',
       array(
          'bla.php' => 'Podnadpis',
          ...
       ),
       'dalsi.php' => Jiny nadpis,
       ...
    );
    
    Hello world ! Segmentation fault (core dumped)

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.