Výukový program JS

JS HOME Úvod do JS JS Kam vést Výstup JS JS prohlášení Syntaxe JS Komentáře JS JS proměnné JS Let JS Const Operátoři JS JS aritmetika Zadání JS JS datové typy Funkce JS JS objekty Události JS JS struny JS String Methods JS String Search Šablony řetězců JS JS čísla Metody čísel JS JS Arrays Metody JS Array JS Array Sort Iterace pole JS JS Array Const JS Termíny Formáty data JS JS metody získávání data JS metody nastavení data JS Math JS Náhodný JS Booleans JS Srovnání Podmínky JS Přepínač JS JS Loop For JS Loop For In JS Loop For Of Zatímco JS Loop JS Break JS Iterables Sady JS Mapy JS Typ JS Konverze typu JS JS Bitwise JS RegExp Chyby JS Rozsah JS JS Zvedací zařízení Přísný režim JS JS toto klíčové slovo Funkce šipky JS JS třídy JS JSON Ladění JS Průvodce stylem JS JS Best Practices Chyby JS Výkon JS JS Reserved Words

Verze JS

Verze JS JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS IE / Edge Historie JS

JS objekty

Definice objektů Vlastnosti objektu Objektové metody Zobrazení objektu Objektové přístupové objekty Konstruktory objektů Prototypy objektů Iterovatelné objekty Sady objektů Mapy objektů Reference objektu

Funkce JS

Definice funkcí Funkční parametry Vyvolání funkce Volání funkce Funkce Použít Funkční uzávěry

JS třídy

Úvod do třídy Třídní dědičnost Třída Statická

JS Async

JS zpětná volání JS asynchronní JS Sliby JS Async/Await

JS HTML DOM

Úvod do DOM Metody DOM Dokument DOM Prvky DOM DOM HTML Formuláře DOM DOM CSS DOM animace Události DOM DOM Event Listener Navigace DOM DOM uzly Kolekce DOM Seznamy uzlů DOM

Kusovník prohlížeče JS

Okno JS Obrazovka JS Umístění JS Historie JS JS Navigator Popup Alert JS Časování JS Soubory cookie JS

Webová rozhraní API JS

Úvod do webového rozhraní API Web Forms API Webová historie API Web Storage API Web Worker API Web Fetch API Web Geolocation API

JS AJAX

Úvod do AJAXu AJAX XMLHttp Požadavek AJAX Odpověď AJAX Soubor XML AJAX AJAX PHP AJAX ASP Databáze AJAX Aplikace AJAX Příklady AJAX

JS JSON

Úvod do JSON Syntaxe JSON JSON vs XML Datové typy JSON Analýza JSON JSON Stringify Objekty JSON Pole JSON Server JSON JSON PHP JSON HTML JSON JSONP

JS vs jQuery

Selektory jQuery HTML jQuery jQuery CSS jQuery DOM

Grafika JS

Grafika JS JS Canvas JS Plotly JS Chart.js JS Google Chart JS D3.js

Příklady JS

Příklady JS JS HTML DOM Vstup HTML JS JS HTML objekty JS HTML události Prohlížeč JS Editor JS Cvičení JS JS kvíz Certifikát JS

JS Reference

Objekty JavaScriptu HTML DOM objekty


JavaScriptové řetězce

Řetězce JavaScriptu slouží k ukládání a manipulaci s textem.

Řetězec JavaScriptu obsahuje nula nebo více znaků napsaných v uvozovkách.

Příklad

let text = "John Doe";

Můžete použít jednoduché nebo dvojité uvozovky:

Příklad

let carName1 = "Volvo XC60";  // Double quotes
let carName2 = 'Volvo XC60';  // Single quotes

Uvozovky můžete použít uvnitř řetězce, pokud se neshodují s uvozovkami obklopujícími řetězec:

Příklad

let answer1 = "It's alright";
let answer2 = "He is called 'Johnny'";
let answer3 = 'He is called "Johnny"';

Délka struny

Chcete-li zjistit délku řetězce, použijte vestavěnou lengthvlastnost:

Příklad

let text = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
let length = text.length;


Útěk postava

Protože řetězce musí být psány v uvozovkách, JavaScript tento řetězec špatně pochopí:

let text = "We are the so-called "Vikings" from the north.";

Řetězec bude přerušen na "Jsme tzv.".

Řešením, jak se tomuto problému vyhnout, je použití znaku escape zpětného lomítka .

Znak escape zpětného lomítka ( \) změní speciální znaky na znaky řetězce:

Code Result Description
\' ' Single quote
\" " Double quote
\\ \ Backslash

Sekvence \"  vloží dvojitou uvozovku do řetězce:

Příklad

let text = "We are the so-called \"Vikings\" from the north.";

Sekvence \'  vloží jednu uvozovku do řetězce:

Příklad

let text= 'It\'s alright.';

Sekvence \\  vloží zpětné lomítko do řetězce:

Příklad

let text = "The character \\ is called backslash.";

V JavaScriptu je platných šest dalších escape sekvencí:

Code Result
\b Backspace
\f Form Feed
\n New Line
\r Carriage Return
\t Horizontal Tabulator
\v Vertical Tabulator

6 escape znaků výše bylo původně navrženo k ovládání psacích strojů, dálnopisů a faxů. V HTML nedávají žádný smysl.


Prolomení dlouhých řádků kódu

Pro nejlepší čitelnost se programátoři často rádi vyhýbají řádkům kódu delším než 80 znaků.

Pokud se příkaz JavaScript nevejde na jeden řádek, nejlepší místo pro jeho přerušení je po operátoru:

Příklad

document.getElementById("demo").innerHTML =
"Hello Dolly!";

Řádek kódu v textovém řetězci můžete také rozdělit jedním zpětným lomítkem:

Příklad

document.getElementById("demo").innerHTML = "Hello \
Dolly!";

Metoda \není preferovanou metodou. Nemusí mít univerzální podporu.
Některé prohlížeče nepovolují mezery za \znakem.

Bezpečnějším způsobem, jak rozdělit řetězec, je použít sčítání řetězce:

Příklad

document.getElementById("demo").innerHTML = "Hello " +
"Dolly!";

Řádek kódu nemůžete rozdělit zpětným lomítkem:

Příklad

document.getElementById("demo").innerHTML = \
"Hello Dolly!";

Řetězce JavaScriptu jako objekty

Normálně jsou řetězce JavaScriptu primitivní hodnoty vytvořené z literálů:

let x = "John";

Ale řetězce lze také definovat jako objekty s klíčovým slovem new:

let y = new String("John");

Příklad

let x = "John";
let y = new String("John");

Nevytvářejte objekty Strings.

Klíčové newslovo komplikuje kód a zpomaluje rychlost provádění.

Objekty typu String mohou způsobit neočekávané výsledky:

Při použití ==operátoru se x a y rovnají :

let x = "John";
let y = new String("John");

Při použití ===operátoru se x a y nerovnají :

let x = "John";
let y = new String("John");

Všimněte si rozdílu mezi (x==y)a (x===y).

(x == y)pravda nebo lež?

let x = new String("John");
let y = new String("John");

(x === y)pravda nebo lež?

let x = new String("John");
let y = new String("John");

Porovnání dvou objektů JavaScriptu vždy vrátí hodnotu false .

Kompletní odkaz na řetězec

Úplnou referenci String naleznete na naší stránce:

Kompletní reference JavaScriptového řetězce .

Odkaz obsahuje popisy a příklady všech vlastností a metod řetězců.

Otestujte se pomocí cvičení

Cvičení:

Použijte lengthvlastnost k upozornění na délku txt.

let txt = "Hello World!";
let x = ;
alert(x);