Jak používat Selen IDE se skripty & Příkazy (Assert, Verify)

Obsah:

Anonim

Jako testovanou webovou aplikaci budeme používat web Mercury Tours. Jedná se o online rezervační systém letů, který obsahuje všechny prvky, které pro tento tutoriál potřebujeme. Jeho URL je http://demo.guru99.com/test/newtours/ a toto bude naše základní URL.

Vytvořte skript nahráváním

Vytvořme nyní náš první testovací skript v selenovém IDE pomocí nejběžnější metody - nahráváním. Poté provedeme náš skript pomocí funkce přehrávání.

Krok 1

  • Spusťte Firefox a Selenium IDE.
  • Zadejte hodnotu pro naši základní adresu URL: http://demo.guru99.com/test/newtours/.
  • Zapněte tlačítko Záznam (pokud ještě není ve výchozím nastavení zapnuto).
Krok 2

Ve Firefoxu přejděte na http://demo.guru99.com/test/newtours/. Firefox by vás měl přesměrovat na stránku podobnou té, která je uvedena níže.

Krok 3
  • Klepněte pravým tlačítkem na prázdné místo na stránce, například na logo Mercury Tours v levém horním rohu. Tím se vyvolá kontextová nabídka IDE selenu. Poznámka: Neklikejte na žádné hypertextové odkazy na objekty nebo obrázky
  • Vyberte možnost „Zobrazit dostupné příkazy“.
  • Poté vyberte možnost „assertTitle exact: Welcome: Mercury Tours“. Toto je příkaz, který zajišťuje správnost názvu stránky.
Krok 4
  • Do textového pole „Uživatelské jméno“ v Mercury Tours zadejte neplatné uživatelské jméno „invalidUNN“.
  • Do textového pole „Heslo“ zadejte neplatné heslo „invalidPWD“.
Krok 5
  • Klikněte na tlačítko „Přihlásit se“. Firefox by vás měl přejít na tuto stránku.
Krok 6

Chcete-li zastavit nahrávání, vypněte tlačítko nahrávání. Váš skript by nyní měl vypadat jako ten, který je zobrazen níže.

Krok 7

Teď, když jsme hotovi s naším testovacím skriptem, uložíme ho do testovacího případu. V nabídce Soubor vyberte možnost „Uložit testovací případ“. Případně můžete jednoduše stisknout Ctrl + S.

Krok 8
  • Vyberte požadované umístění a pojmenujte testovací případ jako „Invalid_login“.
  • Klikněte na tlačítko „Uložit“.
Krok 9.

Všimněte si, že soubor byl uložen jako HTML.

Krok 10.

Vraťte se do Selenium IDE a kliknutím na tlačítko Přehrát spusťte celý skript. Selen IDE by mělo být schopné replikovat vše bezchybně.

Úvod do příkazů selenu - selenština

  • Selenské příkazy mohou mít maximálně dva parametry: cíl a hodnotu.
  • Parametry nejsou vždy vyžadovány. Záleží na tom, kolik bude příkaz potřebovat.

3 typy příkazů

Akce

Jedná se o příkazy, které přímo interagují s prvky stránky.

Příklad: příkaz „kliknout“ je akce, protože přímo komunikujete s prvkem, na který klikáte.

Příkaz „typ“ je také akce, protože vkládáte hodnoty do textového pole a textové pole vám je na oplátku zobrazí. Mezi vámi a textovým polem existuje obousměrná interakce.

Přistupující osoby

Jsou to příkazy, které vám umožňují ukládat hodnoty do proměnné.

Příklad: příkaz „storeTitle“ je přístupový objekt, protože pouze „čte“ nadpis stránky a ukládá jej do proměnné. Neinteraguje s žádným prvkem na stránce.

Tvrzení

Jsou to příkazy, které ověřují, zda je splněna určitá podmínka.

3 typy tvrzení

  • Tvrdit . Pokud příkaz „assert“ selže, test se okamžitě zastaví.
  • Ověřit . Když selže příkaz „ověřit“, Selenium IDE zaznamená tuto chybu a pokračuje v provádění testu.
  • Počkej na . Než přejdete k dalšímu příkazu, budou příkazy „waitFor“ nejprve čekat na splnění určité podmínky.
    • Pokud se podmínka stane pravdivou během čekací doby, krok projde.
    • Pokud se podmínka nestane pravdivou, krok selže. Selhání je protokolováno a provádění testu pokračuje dalším příkazem.
    • Ve výchozím nastavení je hodnota časového limitu nastavena na 30 sekund. Můžete to změnit v dialogovém okně Možnosti IDE selenu na kartě Obecné.

Assert vs. Verify

Společné příkazy

Příkaz Počet parametrů Popis
otevřeno 0 - 2

Otevře stránku pomocí adresy URL.

click / clickAndWait 1

Klikne na zadaný prvek.

typ / typKlíče 2

Zadá posloupnost znaků.

verifyTitle / assertTitle 1

Porovná skutečný název stránky s očekávanou hodnotou.

verifyTextPresent 1

Zkontroluje, zda se na stránce nachází určitý text.

verifyElementPresent 1

Zkontroluje přítomnost určitého prvku.

ověřitTabulka 2

Porovná obsah tabulky s očekávanými hodnotami.

waitForPageToLoad 1

Pozastaví provádění, dokud se stránka nenačte úplně.

waitForElementPresent 1

Pozastaví provádění, dokud nebude uveden zadaný prvek.

Vytvořte skript ručně pomocí Firebug

Nyní vytvoříme stejný testovací případ ručně zadáním příkazů. Tentokrát budeme muset použít Firebug.

Krok 1
  • Otevřete prohlížeč Firefox a Selenium IDE.
  • Zadejte základní adresu URL (http://demo.guru99.com/test/newtours/).
  • Tlačítko záznamu by mělo být VYPNUTO.
Krok 2: Klikněte na nejvyšší prázdný řádek v editoru.

Do textového pole Příkaz zadejte „otevřít“ a stiskněte klávesu Enter.

Krok 3
  • Přejděte Firefox na naši základní adresu URL a aktivujte Firebug
  • V podokně editoru IDE Selenium vyberte druhý řádek (řádek pod příkazem „otevřít“) a vytvořte druhý příkaz zadáním „assertTitle“ do pole Příkaz.
  • Klidně použijte funkci automatického doplňování.
Krok 4
  • Ve Firebugu rozbalte značku , aby se zobrazila značka .</li> <li>Klikněte na hodnotu značky <title> (což je „Welcome: Mercury Tours“) a vložte ji do pole Target v Editoru.</li> </ul> </td> </tr> <tr> <td><strong>Krok 5</strong> <ul> <li>Chcete-li vytvořit třetí příkaz, klikněte na třetí prázdný řádek v editoru a zadejte „text“ do textového pole Příkaz.</li> <li>Ve Firebugu klikněte na tlačítko „Zkontrolovat“.</li> </ul> </td> </tr> <tr> <td>Klikněte na textové pole Uživatelské jméno. Všimněte si, že Firebug vám automaticky zobrazí HTML kód pro tento prvek.</td> </tr> <tr> <td><strong>Krok 6</strong> <p>Všimněte si, že textové pole Uživatelské jméno nemá ID, ale má atribut NAME. Proto budeme jako vyhledávač používat jeho NÁZEV. Zkopírujte hodnotu JMÉNO a vložte ji do pole Cíl v Selenium IDE.</p> <p>V textovém poli Cílová předpona „userName“ s „name =“, což znamená, že selenové IDE by mělo cílit na prvek, jehož atribut NAME je „userName“.</p> <p>Do textového pole Hodnota selenového IDE napište „invalidUN“. Váš testovací skript by nyní měl vypadat jako na obrázku níže. S třetím příkazem jsme skončili. Poznámka: Místo neplatného UN můžete zadat jakýkoli jiný textový řetězec. Selenium IDE ale rozlišuje velká a malá písmena a vy zadáváte hodnoty / atributy přesně jako v aplikaci.</p> </td> </tr> <tr> <td><strong>Krok 7</strong> <ul> <li>Chcete-li vytvořit čtvrtý příkaz, zadejte do textového pole Příkaz „zadejte“.</li> <li>Pomocí tlačítka Firebug „Zkontrolovat“ znovu získáte lokátor textového pole „Heslo“.</li> </ul> <ul> <li> <p>Vložte atribut JMÉNO („heslo“) do pole Cíl a vložte před něj „name =“</p> </li> <li> <p>Do pole Hodnota v Selenium IDE napište „invalidPW“. Váš testovací skript by nyní měl vypadat jako na obrázku níže.</p> </li> </ul> </td> </tr> <tr> <td><strong>Krok 8</strong> <ul> <li>U pátého příkazu zadejte do textového pole Příkaz v IDE selenu „clickAndWait“.</li> <li>Pomocí tlačítka „Zkontrolovat“ Firebug získáte vyhledávač pro tlačítko „Přihlásit se“.</li> </ul> <ul> <li>Vložte hodnotu atributu JMÉNO („přihlášení“) do textového pole Cíl a přidejte před něj „name =“.</li> <li>Váš testovací skript by nyní měl vypadat jako na obrázku níže.</li> </ul> </td> </tr> </tbody> </table> <p><strong>Krok 9:</strong> Uložte testovací případ stejným způsobem jako v předchozí části.</p> <a id="menu-6"></a> <h2>Pomocí tlačítka Najít</h2> <p><strong>Tlačítko Najít v IDE selenu slouží k ověření, zda to, co jsme vložili do textového pole Cíl, je skutečně správný prvek uživatelského rozhraní.</strong></p> <p>Použijme testovací případ Invalid_login, který jsme vytvořili v předchozích částech. Klikněte na libovolný příkaz se záznamem Target, řekněme třetí příkaz.</p> <p>Klikněte na tlačítko Najít. Všimněte si, že textové pole Uživatelské jméno na stránce Mercury Tours se na okamžik zvýrazní.</p> <p>To naznačuje, že IDE selenu dokázalo správně detekovat a přistupovat k očekávanému prvku. Pokud tlačítko Najít zvýraznilo jiný prvek nebo vůbec žádný, pak musí být ve vašem skriptu něco špatně.</p> <a id="menu-7"></a> <h2>Proveďte příkaz</h2> <p><strong>To vám umožní provést libovolný jeden příkaz bez spuštění celého testovacího případu</strong> . Stačí kliknout na řádek, který chcete provést, a poté buď kliknout na „Akce> Spustit tento příkaz“ z řádku nabídek nebo jednoduše stisknout „X“ na klávesnici.</p> <p><strong>Krok 1.</strong> Ujistěte se, že je váš prohlížeč na domovské stránce Mercury Tours. Klikněte na příkaz, který chcete provést. V tomto příkladu klikněte na řádek „type | userName | invalidUN“.</p> <p><strong>Krok 2.</strong> Stiskněte „X“ na klávesnici.</p> <p><strong>Krok 3.</strong> Všimněte si, že textové pole pro uživatelské jméno bude vyplněno textem „invalidUN“</p> <p><strong>Provádění příkazů tímto způsobem je vysoce závislé na stránce, kterou Firefox aktuálně zobrazuje</strong> . To znamená, že pokud vyzkoušíte výše uvedený příklad se zobrazenou domovskou stránkou Google namísto Mercury Tours, váš krok se nezdaří, protože na domovské stránce Google není žádné textové pole s atributem „userName“.</p> <a id="menu-8"></a> <h2>Startovní bod</h2> <p><strong>Počáteční bod je indikátor, který říká selenovému IDE, které řádky začnou s prováděním</strong> . <strong>Jeho klávesová zkratka je „S“.</strong></p> <p>Ve výše uvedeném příkladu se přehrávání spustí na třetím řádku (zadejte | heslo | invalidPW). <strong>V jednom testovacím skriptu můžete mít pouze jeden počáteční bod.</strong></p> <p>Počáteční bod je podobný příkazu Provést v tom, že jsou závislé na aktuálně zobrazené stránce. Počáteční bod selže, pokud jste na nesprávné stránce.</p> <a id="menu-9"></a> <h2>Hraniční body</h2> <p>Hraniční body jsou indikátory, které říkají Selenium IDE, kde má automaticky pozastavit test. <strong>Klávesová zkratka je „B“.</strong></p> <p>Žluté zvýraznění znamená, že aktuální krok čeká na vyřízení. To dokazuje, že selenové IDE v tomto kroku pozastavilo provádění. <strong>V jednom testovacím případě můžete mít více zarážek.</strong></p> <a id="menu-10"></a> <h2>Krok</h2> <p>Umožňuje vám provádět po sobě následující příkazy po pozastavení testovacího případu. Použijme scénář v předchozí části „Hraniční body“.</p> <table> <tbody> <tr> <td width="50%"> </td> <td> <p><strong>Před kliknutím na „Krok“.</strong></p> <p>Testovací případ se pozastaví na řádku „clickAndWait | přihlášení“.</p> </td> </tr> <tr> <td width="50%"> </td> <td> <p><strong>Po kliknutí na „Krok“.</strong></p> <p>Spustí se řádek „clickAndWait | přihlášení“ a pozastaví se na další příkaz (verifyTitle | Sign-on: Mercury Tours).</p> <p>Všimněte si, že další řádek je pozastaven, i když tam není žádný zarážka. To je hlavní účel funkce Krok - provádí následující příkazy jeden po druhém, aby vám poskytl více času na kontrolu výsledku po každém kroku.</p> </td> </tr> </tbody> </table> <a id="menu-11"></a> <h2>Důležité věci, které je třeba si všimnout při použití jiných formátů v zobrazení zdroje</h2> <p><strong>Selenium IDE funguje dobře pouze s HTML - ostatní formáty jsou stále v experimentálním režimu</strong> . Je to <strong>není vhodné</strong> vytvářet nebo upravovat testy za použití jiných formátů zobrazení zdroje, protože tam je ještě hodně práce nezbytná, aby byl stabilní. Níže jsou známé chyby od verze 1.9.1.</p> <ul> <li>Nebudete moci provádět přehrávání ani přepnout zpět do zobrazení tabulky, pokud se nevrátíte k HTML.</li> <li>Jediným způsobem, jak bezpečně přidat příkazy do zdrojového kódu, je jejich záznam.</li> <li>Když zdrojový kód upravíte ručně, při přepnutí na jiný formát dojde ke ztrátě celého kódu.</li> <li>I když můžete svůj testovací případ uložit v zobrazení zdroje, Selenium IDE jej nebude moci otevřít.</li> </ul> <p><strong>Doporučeným způsobem převodu selenských testů je použití možnosti „Exportovat testovací případ jako…“ v nabídce Soubor, nikoli prostřednictvím zobrazení zdroje.</strong></p> <a id="menu-12"></a> <h2>souhrn</h2> <ul> <li>Testovací skripty lze vytvořit buď zaznamenáním nebo ručním zadáním příkazů a parametrů.</li> <li>Při ručním vytváření skriptů se k získání lokátoru používá Firebug.</li> <li>Tlačítko Najít slouží ke kontrole, zda má příkaz přístup ke správnému prvku.</li> <li>Zobrazení tabulky zobrazuje testovací skript ve formě tabulky, zatímco zobrazení zdroje zobrazení ve formátu HTML.</li> <li>Změna zobrazení zdroje na jiný formát než HTML je stále experimentální.</li> <li>Při vytváření testů v jiných formátech nepoužívejte zobrazení zdroje. Místo toho použijte funkce Export.</li> <li>Parametry nejsou vždy vyžadovány. Záleží na příkazu.</li> <li>Existují tři typy příkazů:</li> <ul> <li>Akce - přímo interaguje s prvky stránky</li> <li>Accessors - „čte“ vlastnost prvku a ukládá ji do proměnné</li> <li>Tvrzení - porovnává skutečnou hodnotu s očekávanou</li> </ul> <li>Tvrzení mají tři typy:</li> <ul> <li>Tvrdit - při selhání se další kroky již neprovádějí</li> <li>Ověření - i po selhání budou provedeny následující kroky.</li> <li>WaitFor - projde, pokud se zadaná podmínka stane pravdivou během časového limitu; jinak to selže</li> </ul> <li>Nejběžnější příkazy jsou:</li> <ul> <li>otevřeno</li> <li>click / clickAndWait</li> <li>typ / typKlíče</li> <li>verifyTitle / assertTitle</li> <li>verifyTextPresent</li> <li>verifyElementPresent</li> <li>ověřitTabulka</li> <li>waitForPageToLoad</li> <li>waitForElementPresent</li> </ul> </ul> </div> </article> <div id="container-5533149ee6411a5f99b370c693e87966"></div> </div> </div> </div> </div> </div> <aside class="col-lg-4 sidebar sidebar--right"> <div class="widget widget-popular-posts"> <h2 class="widget-title">Populární Příspěvky</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8002907-columns" title="Sloupce - Triky CSS" rel="bookmark"><img src="https://cdn.css-code.org/2845776/columns_css-tricks.png.webp" loading="lazy" alt="Sloupce - Triky CSS" title="Sloupce - Triky CSS" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8002907-columns" title="Sloupce - Triky CSS" rel="bookmark">Sloupce - Triky CSS 2025</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8002909-column-width" title="Šířka sloupce - Triky CSS" rel="bookmark"><img src="https://cdn.css-code.org/6058826/column-width_css-tricks.png.webp" loading="lazy" alt="Šířka sloupce - Triky CSS" title="Šířka sloupce - Triky CSS" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8002909-column-width" title="Šířka sloupce - Triky CSS" rel="bookmark">Šířka sloupce - Triky CSS 2025</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8002910-column-span" title="Rozpětí sloupců - Triky CSS" rel="bookmark"><img src="https://cdn.css-code.org/7139952/column-span_css-tricks.png.webp" loading="lazy" alt="Rozpětí sloupců - Triky CSS" title="Rozpětí sloupců - Triky CSS" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8002910-column-span" title="Rozpětí sloupců - Triky CSS" rel="bookmark">Rozpětí sloupců - Triky CSS 2025</a></h3> </div> </div> </li> </ul> </div> <div class="widget widget-popular-posts"> <h2 class="widget-title">Nejlepší názory na měsíc</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225605-sql-server-table-create-alter-drop-t-sql-examples" title="Tabulka serveru SQL: CREATE, ALTER, DROP (příklady T-SQL)" rel="bookmark">Tabulka serveru SQL: CREATE, ALTER, DROP (příklady T-SQL)</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225607-create-login-user-assign-permission-sql-server-tutorial" title="Vytvořit přihlášení, uživatel, přiřadit oprávnění: SQL Server Tutorial" rel="bookmark">Vytvořit přihlášení, uživatel, přiřadit oprávnění: SQL Server Tutorial</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225608-oracle-vs-sql-server-key-differences" title="Oracle vs. SQL Server: Klíčové rozdíly" rel="bookmark">Oracle vs. SQL Server: Klíčové rozdíly</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225609-top-40-ssis-interview-questions-and-answers" title="Top 40 SSIS Interview Otázky a odpovědi" rel="bookmark">Top 40 SSIS Interview Otázky a odpovědi</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225611-top-20-ssrs-interview-questions-and-answers" title="Top 20 SSRS Interview Questions & Odpovědi" rel="bookmark">Top 20 SSRS Interview Questions & Odpovědi</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225612-top-50-sql-server-interview-questions-and-answers" title="50 nejlepších dotazů na rozhovor se serverem SQL Odpovědi" rel="bookmark">50 nejlepších dotazů na rozhovor se serverem SQL Odpovědi</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225613-sql-server-tutorial-pdf-for-beginners-download-now" title="Výukový program pro SQL Server PDF pro začátečníky (stáhnout nyní)" rel="bookmark">Výukový program pro SQL Server PDF pro začátečníky (stáhnout nyní)</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225614-uml-diagrams-versions-types-history-tools-examples" title="Diagramy UML: Verze, typy, historie, nástroje, příklady" rel="bookmark">Diagramy UML: Verze, typy, historie, nástroje, příklady</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225615-uml-relationships-with-example-dependency-generalization-realization" title="Vztahy UML s PŘÍKLADEM: Závislost, Zobecnění, Realizace" rel="bookmark">Vztahy UML s PŘÍKLADEM: Závislost, Zobecnění, Realizace</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225616-aggregation-vs-composition-in-uml-key-differences" title="Agregace vs složení v UML: Klíčové rozdíly" rel="bookmark">Agregace vs složení v UML: Klíčové rozdíly</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225617-uml-class-diagram-tutorial-with-examples" title="Výukový program diagramu tříd UML s příklady" rel="bookmark">Výukový program diagramu tříd UML s příklady</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225618-uml-diagram-cheat-sheet-and-reference-guide" title="Cheat Sheet UML Diagram a referenční příručka" rel="bookmark">Cheat Sheet UML Diagram a referenční příručka</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225619-best-28-uml-tools-in-2021" title="NEJLEPŠÍ 28 UML nástrojů v roce 2021" rel="bookmark">NEJLEPŠÍ 28 UML nástrojů v roce 2021</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225620-vb-net-program-structure-module-classes-hello-world-example" title="Struktura, modul, třídy VB.Net programu: Příklad Hello World" rel="bookmark">Struktura, modul, třídy VB.Net programu: Příklad Hello World</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8225621-20-best-visio-alternatives-in-2021-freepaid" title="20 NEJLEPŠÍCH alternativ Visia v roce 2021 (zdarma / placené)" rel="bookmark">20 NEJLEPŠÍCH alternativ Visia v roce 2021 (zdarma / placené)</a></h3> </div> </div> </li> </ul> </div> <div id="container-5533149ee6411a5f99b370c693e87966"></div> <div class="widget widget-popular-posts"> <h2 class="widget-title">Nejlepší Články</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8226481-what-is-informatica-complete-introduction" title="Co je Informatica? Kompletní úvod" rel="bookmark"><img src="https://cdn.css-code.org/1145604/what_is_informatica_complete_introduction.png.webp" loading="lazy" alt="Co je Informatica? Kompletní úvod" title="Co je Informatica? Kompletní úvod" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8226481-what-is-informatica-complete-introduction" title="Co je Informatica? Kompletní úvod" rel="bookmark">Co je Informatica? Kompletní úvod 2025</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8226482-mappings-in-informatica-create-components-parameter-variable" title="Mapování v Informatica: Create, Components, Parameter, Variable" rel="bookmark"><img src="https://cdn.css-code.org/6864256/mappings_in_informatica_create-_components-_parameter-_variable.jpg.webp" loading="lazy" alt="Mapování v Informatica: Create, Components, Parameter, Variable" title="Mapování v Informatica: Create, Components, Parameter, Variable" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8226482-mappings-in-informatica-create-components-parameter-variable" title="Mapování v Informatica: Create, Components, Parameter, Variable" rel="bookmark">Mapování v Informatica: Create, Components, Parameter, Variable 2025</a></h3> </div> </div> </li><li class="post-list-small__item"> <div class="post-list-small__entry clearfix"> <div class="post-list-small__img-holder"> <div class="thumb-container thumb-100"><a href="/8226483-how-to-configure-client-and-repository-in-informatica" title="Jak konfigurovat klienta a úložiště v Informatica" rel="bookmark"><img src="https://cdn.css-code.org/5155376/how_to_configure_client_and_repository_in_informatica.png.webp" loading="lazy" alt="Jak konfigurovat klienta a úložiště v Informatica" title="Jak konfigurovat klienta a úložiště v Informatica" class="post-list-small__img--rounded" style="width:88px;height:88px" /></a></div> </div> <div class="post-list-small__body"> <h3 class="post-list-small__entry-title"><a href="/8226483-how-to-configure-client-and-repository-in-informatica" title="Jak konfigurovat klienta a úložiště v Informatica" rel="bookmark">Jak konfigurovat klienta a úložiště v Informatica 2025</a></h3> </div> </div> </li> </ul> </div> </aside> </div> </div> <footer class="footer footer--dark"> <div class="container"> <div class="footer__widgets"> <div class="row"> <div class="col-lg-4"> <div class="widget"> <h2 class="widget-title">Populární Příspěvky</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8004274-36-current-nav-highlighting-using-php-to-set-the-body-id" title="# 36: Aktuální zvýraznění navigace: Použití PHP k nastavení ID těla - Triky CSS" rel="bookmark"># 36: Aktuální zvýraznění navigace: Použití PHP k nastavení ID těla - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8004275-30-creating-and-sending-html-email" title="# 30: Vytváření a odesílání e-mailů HTML - Triky CSS" rel="bookmark"># 30: Vytváření a odesílání e-mailů HTML - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8004276-38-basics-and-tips-on-designing-for-the-iphone" title="# 38: Základy a tipy pro navrhování pro iPhone - Triky CSS" rel="bookmark"># 38: Základy a tipy pro navrhování pro iPhone - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8004277-39-how-to-use-sifr-3" title="# 39: Jak používat sIFR 3 - Triky CSS" rel="bookmark"># 39: Jak používat sIFR 3 - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8004278-3-converting-a-photoshop-mockup-part-3-of-3" title="# 3: Převod makety aplikace Photoshop (část 3 ze 3) - Triky CSS" rel="bookmark"># 3: Převod makety aplikace Photoshop (část 3 ze 3) - Triky CSS</a></h3> </div> </div> </li> </ul> </div> </div> <div class="col-lg-4"> <div class="widget"> <h2 class="widget-title">Redakce Choice</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8003296-003-content-strategy-session" title="# 003: Sekce obsahové strategie - Triky CSS" rel="bookmark"># 003: Sekce obsahové strategie - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8003297-008-photoshopping-the-module-pattern" title="# 008: Photoshopování vzoru modulu - Triky CSS" rel="bookmark"># 008: Photoshopování vzoru modulu - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8003298-005-adding-slight-dimensionality" title="# 005: Přidání mírné rozměrnosti - Triky CSS" rel="bookmark"># 005: Přidání mírné rozměrnosti - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8003299-006-photoshopping-the-main-navigation" title="# 006: Photoshopping hlavní navigace - Triky CSS" rel="bookmark"># 006: Photoshopping hlavní navigace - Triky CSS</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8003301-009-setting-up-our-local-dev-environment" title="# 009: Nastavení našeho lokálního vývojového prostředí - Triky CSS" rel="bookmark"># 009: Nastavení našeho lokálního vývojového prostředí - Triky CSS</a></h3> </div> </div> </li> </ul> </div> </div> <div class="col-lg-4"> <div class="widget"> <h2 class="widget-title">Nejlepší Články</h2> <ul class="post-list-small"> <li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8222441-jira-tutorial-how-to-use-jira-software-tool-for-beginners" title="Výukový program JIRA: Jak používat softwarový nástroj Jira pro začátečníky" rel="bookmark">Výukový program JIRA: Jak používat softwarový nástroj Jira pro začátečníky</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8222442-learn-sap-testing-create-your-first-sap-test-case" title="Naučte se testování SAP: Vytvořte si svůj první testovací případ SAP" rel="bookmark">Naučte se testování SAP: Vytvořte si svůj první testovací případ SAP</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8222443-sap-security-tutorial-for-beginners-what-is-basics-and-definition" title="Výukový program zabezpečení SAP pro začátečníky: Co je, základy & Definice" rel="bookmark">Výukový program zabezpečení SAP pro začátečníky: Co je, základy & Definice</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8222444-sap-solution-manager-solman-tutorial" title="Výukový program SAP Solution Manager (SolMan)" rel="bookmark">Výukový program SAP Solution Manager (SolMan)</a></h3> </div> </div> </li><li class="post-list-small__item"> <div> <div> <h3 class="post-list-small__entry-title"><a href="/8222446-apache-tutorials-for-beginners" title="Výukové programy Apache pro začátečníky" rel="bookmark">Výukové programy Apache pro začátečníky</a></h3> </div> </div> </li> </ul> </div> </div> </div> <p>© Copyright cs.css-code.org, 2025 Leden | <a href="https://cs.css-code.org/about-site" title="O webu">O webu</a> | <a href="https://cs.css-code.org/contacts" title="Kontakty">Kontakty</a> | <a href="https://cs.css-code.org/privacy-policy" title="Zásady ochrany osobních údajů">Zásady ochrany osobních údajů</a>. </p> </div> </div> </footer> <link href="https://css-code.org/template/css/style.min.css" rel="preload" as="style" onload="this.onload=null;this.rel='stylesheet'" /> </body> </html>