Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.
Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.
Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).
Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.
Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.
Byla vydána říjnová aktualizace aneb nová verze 1.106 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.106 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 5.0.0. Nově je oficiálně podporován Linux ARM64/AArch64. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byla vydána verze 10 dnes již multiplatformního open source frameworku .NET (Wikipedie). Přehled novinek v příspěvku na blogu Microsoftu. Další informace v poznámkách k vydání na GitHubu nebo v přednáškách na právě probíhající konferenci .NET Conf 2025.
Ahoj,
zabývám se návrhem webové aplikace (obecně) a sháním nějaké povídání o návrhových vzorech týkajících se umisťování více věcí na jednu (obvykle HTML) stránku.
Klasické MVC je fajn, ale v podstatě řeší jen onu centrální komponentu, jako je třeba ta na zobrazení dotazu, který právě čtete.
Mě však právě zajímají různé způsoby, jak na stránku elegantně dostat i další věci, jako třeba výpis zpráviček nalevo, menu nahoře, anketu, reklamy, vyhledávací políčko a další věci.
Nevíte tedy o nějakých zajímavých článcích, návrhových vzorech a podobných věcech toho se týkajících (třeba i jen vzdáleně)?
ps: Jde mi o posbírání zajímavých materiálů pro další studium, nikoliv o jedno správné řešení.
. Pokusím se zjednodušeně shrnout podstatu:
V Nette autor používá trochu jinou terminologii - místo MVC používá MVP (Model View Presenter). Kromě Controlleru hrají v Nette důležitou roli komponenty (Control = vykreslitelná komponenta v terminologii Nette). Komponenta - např. nějaká anketa - je napojená na controller, lze ji vykreslit v šabloně, a může přijímat tzv. signály, což jsou odkazy ve tvaru:
"/cesta/v/aplikaci/k/action?do=NAZEV_KOMPONENTY-NAZEV_SIGNALU&NAZEV_KOMPONENTY-NejakyParametr=hodnota"Signál může být např. přičtění hlasu v anketě. Trik je v tom, že konkrétní controller má mechanismus k vyhledání komponenty. Komponenta je představována třídou, jejíž instanci vrací metoda controlleru nazvaná "getComponentNAZEV_KOMPONENTY". Zároveň se tím řeší vytvoření instance komponenty přesně v okamžiku, kdy je poprvé potřeba. Pokud chci stejnou komponentu používat třeba ve všech controllerech, tak je jednoduše podědím od společného předka. Signály od komponent se obsluhují úplně na začátku, ještě před provedením Action. Navíc komponenty jsou uspořádány do stromové struktury, tj. komponenta může obecně obsahovat potomky. V Nette je to elegantně doplněné systémem šablon, kde v příslušné šabloně stačí uvést:
{widget menu $treba_nejaky_parametr}
Šablona má přístup ke controlleru, umí si načíst komponentu "menu" a zavolat na ní metodu render($muze_mit_parametry). V šablonách jde pak snadno generovat odkazy na signály (s tím ?do= na konci).
Obsluha signálů je řešena tak, že komponenta má metodu "handleNAZEV_SIGNALU(...parametry...)".
Podle mě je to celkem elegantní řešení. Zatím jsem do toho úplně neproniknul, ale je tam pár problémů - třeba pokud je potřeba jednu komponentu umístit na stránku vícekrát.
V Nette je nad tím postavena ještě podpora pro AJAX - po přijetí signálu pomocí AJAXu se prohlížeči může poslat vyrenderované HTML změněných komponent - tím lze jednoduše řešit treba to hlasování v anketě na stránce...
Pokud to můžu srovnat třeba se Zend Frameworkem pro PHP, tak tam tohle asi nemá obecné řešení. Viděl jsem řešení, kdy takovéhle komponenty byly realizované jako speciální Controller a Action, pak se v rámci jednoho requestu volaly různé Action, výstup šablony se vždy uložil zvlášť pod nějakým označením, a v hlavní šabloně se to vykreslilo na správná místa.
Propojení komponent se asi obvykle řeší v Controlleru. Konktrétně v tomhle případě je stejně potřeba získat data pro ten seznam z modelu a předat mu je - no a v tomhle okamžiku se na základě těch dat (počet záznamů) a konfigurace (po kolika stránkovat) nastaví stránkovač. Př.:
class NejakyController extends BaseController {
function renderNejakaAction()
{
$model = new NejakyModel();
$data = $model->getData();
$this->getComponentStrankovac->setup($model->count(), POCET_ZAZNAMU_NA_STRANKU);
$model->limitPage($this->getComponentStrankovac->getCurrentPage());
$this->getComponentVypis()->data = $model->getData();
// nebo v Nette lze pouzit:
// $this['vypis']->data = ...;
}
// funkce se schvalne jmenuje 'create...', Controller volani 'getComponent...'
// automaticky prevede na tuto funkci a navrch zajisti propojeni instance
// komponenty s Controllerem. Komponenta pak muze vyuzit Controller ke
// generovani odkazu apod.
function createComponentStrankovac()
{
return new Strankovac();
}
//
function createComponentVypis()
{
return new Vypis();
}
}
Jiná možnost je, že se data pro ten seznam načítají z modelu přímo v té komponentě "seznam", pak stránkování jde udělat jako sub-komponentu toho seznamu a opět v okamžiku načtení dat se počet stránek nastaví té sub-komponentě. Tohle nijak neomezuje možnosti vykreslení v šabloně - lze samostatně vykreslit seznam a stránkování přesně jak je potřeba. Jedna komponenta obecně nemusí být vykreslena v jednom bloku v šabloně, jde spíš o "logickou" část stránky.
Je možné také řešení, kdy obě komponenty budou připojeny ke controlleru, a třeba ta komponenta na stránkování se zevnitř dostane k seznamu:$pocetStran = $this->getController()->getComponentSeznam()->getPageCount();
Tím se ale podle mě omezí znovupoužitelnost té komponenty, protože pevně předpokládá existenci "seznam" v Controlleru. Co když budu mít těch seznamů na stránce víc?
Tiskni
Sdílej: