Čo je EJS a prečo ho potrebujem?

Čo je EJS a prečo ho potrebujem?

Pri vývoji webových aplikácií je k dispozícii veľa nástrojov, z ktorých si môžu vývojári vybrať. Výber správnych nástrojov a technológií môže mať významný vplyv na efektivitu a funkčnosť projektov. Jedným z populárnych nástrojov vo vývoji webu je EJS, čo je skratka pre Embedded JavaScript . EJS je jednoduchý šablónovací jazyk JavaScript, ktorý generuje HTML s obyčajným JavaScriptom. V tomto článku sa budeme zaoberať tým, čo je EJS, prečo je potrebný, jeho funkcie, ako ho nainštalovať a poskytneme príklad s výstupom.

Čo je EJS

EJS alebo Embedded JavaScript je nástroj šablón pre JavaScript, ktorý sa používa na vývoj webových aplikácií, ktorý umožňuje používateľom vytvárať dynamické značky HTML pomocou kódu JavaScript v rámci šablón HTML. Je navrhnutý tak, aby zjednodušil proces vykresľovania dynamického obsahu vo webových aplikáciách. Obsahuje zmes HTML a JavaScriptu, ktorá uľahčuje generovanie dynamického obsahu na základe údajov z vašej aplikácie.

Vlastnosti EJS

  • Jednoduchá syntax: EJS ponúka priamu syntax, ktorá kombinuje HTML a JavaScript, čo uľahčuje učenie a používanie.
  • Dynamický obsah: EJS umožňuje generovanie obsahu HTML a JavaScript dynamicky v rámci značiek HTML, čím sa zvyšuje flexibilita pri vytváraní obsahu.
  • Rozloženie a časti: EJS podporuje rozloženia a časti, čo používateľom umožňuje rozdeliť šablóny na opakovane použiteľné komponenty, čím sa znižuje duplicita kódu a zlepšuje sa udržiavateľnosť.
  • Spracovanie chýb: EJS poskytuje chybové hlásenia, ktoré pomáhajú vývojárom pri ladení a zlepšujú celkový zážitok z vývoja.

Prečo potrebujete EJS?

  • Dynamické generovanie HTML: EJS vám umožňuje generovať dynamický obsah HTML na základe premenných, podmienok, slučiek a inej logiky JavaScriptu. Toto je obzvlášť užitočné pri vykresľovaní dynamických údajov získaných z databáz alebo rozhraní API.
  • Opätovná použiteľnosť kódu: Pomocou šablón EJS môžete vytvárať opakovane použiteľné komponenty alebo časti, ktoré možno zahrnúť do viacerých stránok. To podporuje modularitu kódu a znižuje duplicitu vo vašich webových aplikáciách.
  • Vykresľovanie na strane servera: Pomocou EJS môžete vykonávať vykresľovanie webových stránok na strane servera (SSR). SSR je prínosom pre SEO (optimalizáciu pre vyhľadávače), pretože umožňuje vyhľadávacím nástrojom prehľadávať a indexovať váš obsah efektívnejšie v porovnaní s vykresľovaním na strane klienta (CSR), ktoré vykonávajú rámce ako React alebo Angular.
  • Jednoduchá integrácia s Node.js a Express.js: EJS sa hladko integruje s Node.js a Express.js, vďaka čomu je obľúbenou voľbou pre vývojárov pracujúcich na aplikáciách JavaScript na strane servera. Je ľahké ho nastaviť a používať v rámci projektu Express.js.
  • Známa syntax: Ak už poznáte HTML a JavaScript, učenie a používanie EJS je jednoduché. Syntax je podobná HTML s vloženým kódom JavaScript > tagy, vďaka čomu je prístupný pre vývojárov s rôznou úrovňou zručností.
  • Dedičnosť šablóny a rozloženia: EJS podporuje dedenie šablón a rozloženia, čo vám umožňuje vytvárať konzistentné rozloženia vašich webových stránok. Môžete definovať základné rozloženie a rozšíriť ho v iných šablónach, čím si uľahčíte zachovanie konzistentného vzhľadu a štýlu v celej aplikácii.

Ako používať EJS?

Krok 1: Nainštalujte EJS ako závislosť vo svojom projekte

 npm install ejs 

Krok 2: Vytvorte priečinok „views“ v adresári projektu, ak ešte neexistuje. V priečinku views vytvorte nový súbor s príponou .ejs, napríklad index.ejs

Krok 3: Ak chcete integrovať EJS s Express v aplikácii Express.js, nastavte EJS ako zobrazovací mechanizmus v konfigurácii aplikácie Express. Táto konfigurácia umožňuje Express používať EJS na vykresľovanie pohľadov.

app.set('view engine', 'ejs'); 

Krok 4: Vykreslenie šablóny EJS, vo vašich obslužných programoch expresnej cesty vykreslíme šablónu EJS pomocou „res.render()“ a poskytnúť potrebné údaje, ktoré sa majú odovzdať do šablóny.

res.render('hello', { name: 'Geeks' }); 

Štruktúra projektu:

projektový_adresár

Aktualizované závislosti v package.json súbor bude vyzerať takto:

'dependencies': {  'ejs': '^3.1.9',  'express': '^4.18.2'  } 

Príklad: Implementácia na ukážku použitia ejs s príkladom.

HTML
          Príklad EJS> hlava> <body>  <h1>Ahoj, <%= name %>!h1> body> html> </pre>  </code>JavaScript <code>  <pre>// index.js  const express = require('express'); const app = express(); const port = 3000; app.set('view engine', 'ejs'); app.get('/', (req, res) =>{ res.render('ahoj', { meno: 'Geeks' }); }); app.listen(port, () => { console.log(`Server beží na http://localhost:${port}`); }); </pre>  </code>  <p dir='ltr'>  <b>  <strong>Krok na spustenie aplikácie: </strong>  </b>  <span>Spustite aplikáciu pomocou nasledujúceho príkazu z koreňového adresára projektu </span> </p>  <pre>node index.js </pre> <p dir='ltr'>  <b>  <strong>Výkon: </strong>  </b>  <span>Váš projekt sa zobrazí na adrese URL http://localhost:3000/ </span> </p>  <p dir='ltr'> <img src='//techcodeview.com/img/ejs-templating-language/39/what-is-ejs-why-do-i-need-it-2.webp' alt='výkon'> </p>  <br>  <br>
                     </div>

                     <!-- Article Footer with Prominent Share Buttons -->
                     <div class="px-6 md:px-8 py-8 bg-slate-50 dark:bg-slate-900/50 border-t border-slate-200 dark:border-slate-700/50">
                          <div class="flex flex-col sm:flex-row items-center justify-between gap-6">
                              <h4 class="text-base font-bold text-slate-700 dark:text-slate-300 uppercase tracking-wide flex items-center gap-2">
                                 <i class="fa fa-share-alt text-tech-500"> </i>
                                Zdieľať                              </h4>
                             
                              <div class="flex flex-wrap justify-center gap-3">
                                 <!-- Twitter -->
                                 <a href="https://twitter.com/intent/tweet?text=Čo je EJS a prečo ho potrebujem?&url=https://www.techcodeview.com/sk/what-is-ejs-why-do-i-need-it" 
                                   target="_blank" rel="noopener noreferrer" 
                                   class="flex items-center gap-2 px-6 py-3 rounded-xl bg-[#1DA1F2]/10 text-[#1DA1F2] hover:bg-[#1DA1F2] hover:text-white transition-all duration-300 font-bold text-sm">
                                     <i class="fa fa-twitter text-lg"> </i>
                                     <span class="hidden sm:inline">Twitter </span>
                                 </a>

                                 <!-- Facebook -->
                                 <a href="https://www.facebook.com/sharer/sharer.php?u=https://www.techcodeview.com/sk/what-is-ejs-why-do-i-need-it" 
                                   target="_blank" rel="noopener noreferrer"
                                   class="flex items-center gap-2 px-6 py-3 rounded-xl bg-[#4267B2]/10 text-[#4267B2] hover:bg-[#4267B2] hover:text-white transition-all duration-300 font-bold text-sm">
                                     <i class="fa fa-facebook text-lg"> </i>
                                     <span class="hidden sm:inline">Facebook </span>
                                 </a>
                                
                                 <!-- LinkedIn -->
                                 <a href="https://www.linkedin.com/shareArticle?mini=true&url=https://www.techcodeview.com/sk/what-is-ejs-why-do-i-need-it&title=Čo je EJS a prečo ho potrebujem?" 
                                   target="_blank" rel="noopener noreferrer"
                                   class="flex items-center gap-2 px-6 py-3 rounded-xl bg-[#0077b5]/10 text-[#0077b5] hover:bg-[#0077b5] hover:text-white transition-all duration-300 font-bold text-sm">
                                     <i class="fa fa-linkedin text-lg"> </i>
                                     <span class="hidden sm:inline">LinkedIn </span>
                                 </a>
                              </div>
                          </div>
                     </div>
                </article>

                <!-- Comments Placeholder / Random Articles -->
                <div class="mt-8 bg-white dark:bg-slate-800 border border-slate-200 dark:border-slate-700 rounded-xl p-6 md:p-8 shadow-sm">
                     <h3 class="text-xl font-bold text-slate-900 dark:text-white mb-6 uppercase tracking-wide border-b border-slate-200 dark:border-slate-700 pb-2">
                        Mohlo By Sa Vám Páčiť                     </h3>
                     <div class="grid grid-cols-1 md:grid-cols-2 gap-6">
                         <div class="group">
                              <a href="/sk/python-import-from-parent-directory" class="block aspect-video rounded-lg overflow-hidden bg-slate-200 dark:bg-slate-700 mb-3">
                                 <img loading="lazy" src="https://techcodeview.com/img/picked/26/python-import-from-parent-directory.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Python – Import z nadradeného adresára" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                              </a>
                              <h4 class="font-bold text-slate-900 dark:text-white leading-tight group-hover:text-tech-500 transition-colors">
                                 <a href="/sk/python-import-from-parent-directory">Python – Import z nadradeného adresára </a>
                              </h4>
                         </div> <div class="group">
                              <a href="/sk/how-undo-redo-photoshop" class="block aspect-video rounded-lg overflow-hidden bg-slate-200 dark:bg-slate-700 mb-3">
                                 <img loading="lazy" src="https://techcodeview.com/img/photoshop-tutorial/51/how-undo-redo-photoshop.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Ako vrátiť späť / znova vo Photoshope" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                              </a>
                              <h4 class="font-bold text-slate-900 dark:text-white leading-tight group-hover:text-tech-500 transition-colors">
                                 <a href="/sk/how-undo-redo-photoshop">Ako vrátiť späť / znova vo Photoshope </a>
                              </h4>
                         </div>
                     </div>
                </div>
             </div>

             <!-- SECONDARY COLUMN (SIDEBAR) -->
             <!-- Aside Column -->
 <div class="lg:col-span-4 space-y-8">
	
	 <!-- Best Articles Widget -->
	 <div class="rounded-xl bg-white dark:bg-slate-800 border border-slate-200 dark:border-slate-700 p-6 shadow-sm">
		 <div class="mb-4 border-b border-slate-100 dark:border-slate-700 pb-2">
			 <h2 class="text-lg font-bold text-slate-900 dark:text-white uppercase tracking-wide flex items-center">
                 <span class="mr-2 h-2 w-2 rounded-full bg-tech-500"> </span>
                Najlepšie Články             </h2>
		 </div>
		
		 <!-- Owl Carousel Preserved Container -->
		 <div id="owl-carousel-3" class="owl-carousel owl-theme center-owl-nav">
			 <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/300-core-java-interview-questions-set-1">
						 <img src="https://techcodeview.com/img/all-interview/59/300-core-java-interview-questions-set-1.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="300 základných otázok na pohovor Java | Set 1" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/300-core-java-interview-questions-set-1" class="hover:text-tech-500 transition-colors line-clamp-3">300 základných otázok na pohovor Java | Set 1 </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/best-ap-us-government-review-131372">
						 <img src="https://techcodeview.com/img/blog/62/best-ap-us-government-review.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Najlepší prehľad AP americkej vlády: 5-krokový sprievodca" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/best-ap-us-government-review-131372" class="hover:text-tech-500 transition-colors line-clamp-3">Najlepší prehľad AP americkej vlády: 5-krokový sprievodca </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/difference-between-android">
						 <img src="https://techcodeview.com/img/operating-system/44/difference-between-android.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Rozdiel medzi Androidom a Linuxom" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/difference-between-android" class="hover:text-tech-500 transition-colors line-clamp-3">Rozdiel medzi Androidom a Linuxom </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/sql-select-into-statement">
						 <img src="https://techcodeview.com/img/it-problems-solutions/41/sql-select-into-statement.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Príkaz SQL SELECT INTO" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/sql-select-into-statement" class="hover:text-tech-500 transition-colors line-clamp-3">Príkaz SQL SELECT INTO </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/mylivecricket-alternatives">
						 <img src="https://techcodeview.com/img/alternatives/03/mylivecricket-alternatives.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="MyLiveCricket Alternatívy" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/mylivecricket-alternatives" class="hover:text-tech-500 transition-colors line-clamp-3">MyLiveCricket Alternatívy </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/how-round-double">
						 <img src="https://techcodeview.com/img/java-tutorial/83/how-round-double.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Ako zaokrúhliť dvojité a plávať na dve desatinné miesta v Jave?" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/how-round-double" class="hover:text-tech-500 transition-colors line-clamp-3">Ako zaokrúhliť dvojité a plávať na dve desatinné miesta v Jave? </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/i-e-vs-e-g-vs-ex-which-is-which-131124">
						 <img src="https://techcodeview.com/img/blog/98/i-e-vs-e-g-vs-ex-which-is-which.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="T.j. oproti napr. vs.: Ktorá je ktorá?" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/i-e-vs-e-g-vs-ex-which-is-which-131124" class="hover:text-tech-500 transition-colors line-clamp-3">T.j. oproti napr. vs.: Ktorá je ktorá? </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/button-react">
						 <img src="https://techcodeview.com/img/reactjs-tutorial/77/button-react.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Tlačidlo v React" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/button-react" class="hover:text-tech-500 transition-colors line-clamp-3">Tlačidlo v React </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/python-requests-tutorial">
						 <img src="https://techcodeview.com/img/python-requests/43/python-requests-tutorial.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Návod na požiadavky Pythonu" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/python-requests-tutorial" class="hover:text-tech-500 transition-colors line-clamp-3">Návod na požiadavky Pythonu </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE --> <!-- ARTICLE -->
			 <article class="flex items-start gap-4 p-2 hover:bg-slate-50 dark:hover:bg-slate-700/50 rounded-lg transition-colors">
				 <div class="w-20 h-20 shrink-0 overflow-hidden rounded-md bg-slate-200 dark:bg-slate-700">
					 <a href="/sk/list-cities-usa">
						 <img src="https://techcodeview.com/img/list/63/list-cities-usa.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Zoznam miest v USA" class="w-full h-full object-cover">
					 </a>
				 </div>
				 <div class="flex-1 min-w-0">
					 <h4 class="text-sm font-semibold text-slate-800 dark:text-slate-200 leading-snug">
                         <a href="/sk/list-cities-usa" class="hover:text-tech-500 transition-colors line-clamp-3">Zoznam miest v USA </a>
                     </h4>
				 </div>
			 </article>
			 <!-- /ARTICLE -->
		 </div>
		

         <!-- Categories -->
		 <div class="mt-8 mb-4 border-b border-slate-100 dark:border-slate-700 pb-2">
			 <h2 class="text-lg font-bold text-slate-900 dark:text-white uppercase tracking-wide">Kategórie </h2>
		 </div>
		 <div class="flex flex-wrap gap-2">
             <a href="/sk/blog/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Blog
             </a> <a href="/sk/java-conversion/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Konverzia Java
             </a> <a href="/sk/maths/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Matematika
             </a> <a href="/sk/java-collections/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Kolekcie Java
             </a> <a href="/sk/differences/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Rozdiely
             </a> <a href="/sk/java-string/" class="inline-block px-3 py-1 bg-slate-100 dark:bg-slate-700 text-xs font-medium text-slate-600 dark:text-slate-300 rounded-full hover:bg-tech-500 hover:text-white transition-colors">
                Java Reťazec
             </a>
         </div>

         <!-- Interesting Articles Widget -->
		 <div class="mt-8">
			 <div class="mb-4 border-b border-slate-100 dark:border-slate-700 pb-2">
				 <h2 class="text-lg font-bold text-slate-900 dark:text-white uppercase tracking-wide">Zaujímavé Články </h2>
			 </div>
			
			 <div id="owl-carousel-4" class="owl-carousel owl-theme">
				 <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/chemistry-class-11/04/aufbau-principle.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Princíp štruktúry" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/chemistry-class-11-cat/">Chémia-Trieda-11 </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/aufbau-principle">Princíp štruktúry </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE --> <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/c-tutorial/33/socket-programming-c-c.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Soketové programovanie v C/C++" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/c-tutorial/">C++ Návod </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/socket-programming-c-c">Soketové programovanie v C/C++ </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE --> <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/blog/70/ultimate-guide-ap-statistics-exam.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Konečný sprievodca skúškou AP Statistics" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/blog/">Blog </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/ultimate-guide-ap-statistics-exam-1311274">Konečný sprievodca skúškou AP Statistics </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE --> <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/python-tutorial/89/atom-python.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Atom Python" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/python-tutorial/">Návod Na Python </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/atom-python">Atom Python </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE --> <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/it-problems-solutions/39/what-is-docker.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Čo je Docker?" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/it-problems-solutions/">It Problémy A Riešenia </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/what-is-docker">Čo je Docker? </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE --> <!-- ARTICLE -->
				 <article class="relative aspect-video rounded-lg overflow-hidden group mb-2">
					 <div class="absolute inset-0">
						 <img src="https://techcodeview.com/img/dsa/28/rearrange-a-given-list-such-that-it-consists-of-alternating-minimum-maximum-elements.webp" onerror="this.onerror=null; this.src='https://techcodeview.com/template/assets/images/unnamed.webp'" alt="Usporiadajte daný zoznam tak, aby pozostával zo striedajúcich sa minimálnych maximálnych prvkov" class="w-full h-full object-cover group-hover:scale-105 transition-transform duration-500">
                         <div class="absolute inset-0 bg-gradient-to-t from-black/80 to-transparent"> </div>
					 </div>
					 <div class="absolute bottom-0 left-0 p-4">
						 <div class="text-xs text-tech-400 font-bold mb-1"> <a href="/sk/dsa/">DSA </a> </div>
						 <h4 class="text-sm font-bold text-white leading-tight"> <a href="/sk/rearrange-a-given-list-such-that-it-consists-of-alternating-minimum-maximum-elements">Usporiadajte daný zoznam tak, aby pozostával zo striedajúcich sa minimálnych maximálnych prvkov </a> </h4>
					 </div>
				 </article>
				 <!-- /ARTICLE -->
			 </div>
		 </div>
	 </div>
 </div>
 <!-- /Aside Column -->         </div>
        </div>
     </div>

 <footer class="site-footer">
         <div class="container">
             <span class="footer-links">
                Copyright ©2026 Všetky Práva Vyhradené | 
                 <a href="//www.techcodeview.com/hr/">techcodeview.com </a> | 
                 <a href="/disclaimer" rel="nofollow noopener noreferrer" target="_blank">Odmietnutie Zodpovednosti </a> | 
                 <a href="/about-us" rel="nofollow noopener noreferrer" target="_blank">O Nás </a> | 
                 <a href="/privacy-policy" rel="nofollow noopener noreferrer" target="_blank">Zásady Ochrany Osobných Údajov </a> 
             </span>
         </div>
     </footer>
 
     <script type="text/javascript" src="https://techcodeview.com/template/assets/plugins/jquery-1.11.3.min.js"> </script>
     <script type="text/javascript" src="https://techcodeview.com/template/assets/plugins/bootstrap/js/bootstrap.min.js"> </script>    
     <script type="text/javascript" src="https://techcodeview.com/template/assets/js/main.js"> </script>     
	 <script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/11.5.1/highlight.min.js"> </script>
	 <script>
    !function(){"use strict";let t=document.createElement("button");t.id="toTopBtn",t.innerHTML="↑";let e=`
        #toTopBtn {
            position: fixed; bottom: 25px; right: 25px; z-index: 9999; opacity: 0; visibility: hidden; background-color: #0ea5e9; color: white; border: none; border-radius: 8px; width: 50px; height: 50px; font-size: 24px; cursor: pointer; transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
        }
        #toTopBtn:hover { background-color: #0284c7; }
    `,i=document.createElement("style");i.type="text/css",i.innerText=e,document.head.appendChild(i),document.body.appendChild(t),window.addEventListener("scroll",()=>{let e=window.scrollY||document.documentElement.scrollTop;e>300?(t.style.opacity="1",t.style.visibility="visible"):(t.style.opacity="0",t.style.visibility="hidden")}),t.addEventListener("click",()=>{window.scrollTo({top:0,behavior:"smooth"})})}();
     </script>
 </body>
 </html>