Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Eric Migicovsky představil Pebble Emulator, tj. emulátor hodinek Pebble (PebbleOS) běžící ve webovém prohlížeči. Za 6 hodin jej napsal Claude Code. Zdrojové kódy jsou k dispozici na GitHubu.
Byla vydána nová verze 3.41 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.11 souvisejícího programovacího jazyka Dart (Wikipedie).
Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.
Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.
Agent umělé inteligence vytvořil 'útočný' článek o Scottu Shambaughovi, dobrovolném správci knihovny matplotlib, poté, co vývojář odmítl agentem navrženou změnu kódu (pull request). 'Uražený' agent autonomně sepsal a publikoval na svém blogu článek, který přisuzuje Shambaughovi smyšlené motivace, egoismus a strach z AI coby konkurence.
Bylo vydáno Ubuntu 24.04.4 LTS, tj. čtvrté opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
V pátek 20. února 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 6. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj a uživatelský prostor. Akce proběhne od 10:00 do večera. Hackday je určen všem, kteří si chtějí prakticky vyzkoušet práci s linuxovým jádrem i uživatelským prostorem, od posílání patchů například pomocí nástroje b4, přes balíčkování a Flatpak až po drobné úpravy
… více »Zdravim, doteraz pouzivam na dynamicke nastavovanie meta tagov output buffering, co nie je najlepsia volba, vzhladom na spotrebu pamate. Preto hladam nejaky menej narocny sposob na to, aby som mohol vypisovat tieto udaje. Udaje mam uloztene v MySQL databazi a problem je ten, ze celu sekciu HEAD mam nastavenu v header.php a tym padom uz neviem vypisat title, ktory je nastaveny v stranke.
<?php
include "header.php";
include "stranka.php";
include "footer.php";
?>
Ako by som toto mohol riesit? Dakujem.
Možná jen špatně chápu, o co vám jde, ale co si prostě ještě před prvním include nadpis uložit do proměnné (např.) $title?
<?php
include "common.php";
header('Titulek stránky');
echo "tělo stránky";
footer();
?>
Není to úplně ideální a brzy narazíš na omezení i tohoto přístupu, ale do doby než prozkoumáš šablonovací nástroje či rovnou nějaké hotové CMS, ti to asi bude stačit. Pokud to chceš udělat pořádně, podívej se na nějaký pěkný framework.
header() pojmenoval jinak kvůli kolizi.
Jinak tuto techniku jsem dost používal, než jsem přešel na objekty. Mělo to výhodu, že i když někdo uhodl název includovaného souboru a vložil jeho adresu do prohlížeče, nic se neprovedlo.
<?php include "headers.php"; $set_title='Titulek stránky';//případně vyměnit za array include "head.php"; //body include "foot.php";a v
head.php
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/1998/REC-html40-19980424/strict.dtd" >
<html lang="cs">
<head>
<title><?php echo $set_title;?> </title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
...
OT: pojmenováni fce header není nejvhodnější
<?php
function tpl_header($data) {
extract($data); // podle klíčů v $data jsou nadefinovány lokální proměnné
echo 'Hello ', $user, '!';
?>
Nějaký větší kus HTML, kde je málo
kusů PHP, protože to je znatelně pomalejší.
<?php
}
Použití takové šablony je pak jednoduché. Na začátku souboru, kde je použita se udělá jednou require a pak se jen volá funkce, kolikrát je libo:
require 'tpl/header.php';
// ... hromada užitečného kódu
// a nakonec:
tpl_header(array(
'user' => $user_name,
));
Výhodou tohoto je i možnost spojit všechny šablony do jednoho souboru... stačí odstranit první řádek (php tag není uzavřen) a prohnat to catem. A navíc není třeba šablony nijak chránit, protože v nich není nic, co by něco dělalo samo od sebe.
) můžeme debatovat, ono to řešení pře funkce bez class-ů je, dle mého, takové na půl cesty.headers.php do head.php by bylo dost divné, oba by měli jen vstřebávat.$set_title, bo pak je to jedinečné konfigurační pole např.
$glb_setting=Array(headers=>Array('Content-Type: text/html; charset=utf-8'),/*http headers*/
title='Můj title', /*page title*/
robots='index,follow',/*meta robot*/);
které je definováno jako první. Což je taky takové nic moc, bo to není nějaký class.<?php /*inicializace PHP, načtení potřebné konfigurace třeba do array*/ require_once "init.php"; /*věci jako nové proměnné do session, případně změna hlavičky obsahu, mění title, klíčová slova apod*/ require_once "preswicth.php"; /*http hlavičky*/ require_once "headers.php"; /*začátek dokumentu*/ require_once "head.php"; /*obsah, který pravděpodobně include-uje dále*/ require_once "mainswicth.php"; /*ukončení dokumentu*/ require_once "foot.php";nevidím nic špatného a může být někdy i přehlednější než (včetně „funkcionálního“ ekvivalentu):
<?php
require_once "base.php";
require_once "session.php";
require_once "doc.php";
require_once "form.php";
require_once "acontent.php";
$init_array=Array();
require_once "init.php";
Base::Init($init_array);
unset($init_array);
Form::ParseGetPost(/*$_GET,$_POST,$_SESSION*/);
Session::SetSession();
Doc::PrintHeaders();
Doc::PrintBeginDoc();
try{
if($cntnt = Form::GetContentObj())
$cntnt->sendStdBody();
else Doc::PrintTextError('Fatal error');
}catch(Exception $e){
Doc::PrintExceptionError($e);
}
Doc::PrintEndDoc();
PS: obě struktury jsem si teď vymyslel
$stranka=new ViewHTML();
$stranka->setObsah($_REQUEST['strana']);
$stranka->setMenu('filtr');
$stranka->setTitle('Titulek webu');
$stranka->addCSS('style.css');
echo $stranka;
Hlavička i patička se generuje až na posledním řádku, kdy jsou k dispozici všechny datové komponenty a vím, že se nějaká stránka generovat bude.
Tiskni
Sdílej: