Вебтехнології для розробників
- CSS Tutorials
- How to
- WebKit (-webkit-) vendor-prefixed CSS extensions
- Firefox (-moz-) vendor-prefixed CSS extensions
- CSS selectors
- CSS at-rules
- CSS values
- CSS properties
- CSS guides
- HTML guides
- How to
- HTML reference
- Closures
- Enumerability and ownership of properties
- JavaScript data types and data structures
- Equality comparisons and sameness
- Control flow and error handling
- Inheritance and the prototype chain
- Introduction
- Iterators and generators
- Internationalization
- Keyed collections
- JavaScript language overview
- Memory management
- Meta programming
- Numbers and strings
- Representing dates & times
- JavaScript resource management
- JavaScript typed arrays
- Assertions
- Character classes
- Groups and backreferences
- Quantifiers
- Deprecated and obsolete features
- JavaScript execution model
- JavaScript technologies overview
- Trailing commas
- extends
- constructor
- Private elements
- static
- Public class fields
- Static initialization blocks
- Input boundary assertion: ^, $
- Literal character: a, b
- Disjunction: |
- Lookahead assertion: (?=...), (?!...)
- Modifier: (?ims-ims:...)
- Lookbehind assertion: (?<=...), (?<!...)
- Named capturing group: (?<name>...)
- Named backreference: \k<name>
- Non-capturing group: (?:...)
- Quantifier: *, +, ?, {n}, {n,}, {n,m}
- Unicode character class escape: \p{...}, \P{...}
- Wildcard: .
- Word boundary assertion: \b, \B
- Warning: -file- is being assigned a //# sourceMappingURL, but already has one
- TypeError: already executing generator
- SyntaxError: arguments is not valid in fields
- SyntaxError: await/yield expression can\'t be used in parameter
- SyntaxError: await is only valid in async functions, async generators and modules
- TypeError: invalid Array.prototype.sort argument
- SyntaxError: continue must be inside loop
- SyntaxError: unlabeled break must be inside loop or switch
- SyntaxError: new keyword cannot be used with an optional chain
- SyntaxError: tagged template cannot be used with optional chain
- RangeError: radix must be an integer
- SyntaxError: invalid regular expression flag "x"
- SyntaxError: return not in function
- SyntaxError: \'arguments\'/\'eval\' can\'t be defined or assigned to in strict mode code
- SyntaxError: use of super property/member accesses only valid within methods or eval code within methods
- SyntaxError: super() is only valid in derived class constructors
- RangeError: BigInt division by zero
- RangeError: BigInt negative exponent
- TypeError: BigInt value can\'t be serialized in JSON
- TypeError: calling a builtin X constructor without new is forbidden
- TypeError: X.prototype.y called on incompatible type
- ReferenceError: can\'t access lexical declaration \'X\' before initialization
- RangeError: x can\'t be converted to BigInt because it isn\'t an integer
- TypeError: can\'t convert BigInt to number
- TypeError: can\'t assign to property "x" on "y": not an object
- TypeError: property "x" is non-configurable and can\'t be deleted
- TypeError: can\'t convert x to BigInt
- TypeError: can\'t define property "x": "obj" is not extensible
- TypeError: can\'t redefine non-configurable property "x"
- SyntaxError: private fields can\'t be deleted
- TypeError: can\'t set prototype of this object
- SyntaxError: cannot use \`??\` unparenthesized within \`||\` and \`&&\` expressions
- TypeError: class constructors must be invoked with \'new\'
- TypeError: cyclic object value
- TypeError: Iterator/AsyncIterator constructor can\'t be used directly
- SyntaxError: applying the \'delete\' operator to an unqualified name is deprecated
- TypeError: can\'t set prototype: it would cause a prototype chain cycle
- TypeError: \'caller\', \'callee\', and \'arguments\' properties may not be accessed
- SyntaxError: octal escape sequences can\'t be used in untagged template literals or in strict mode code
- SyntaxError: Using //@ to indicate sourceURL pragmas is deprecated. Use //# instead
- SyntaxError: "0"-prefixed octal literals are deprecated
- SyntaxError: duplicate formal argument x
- SyntaxError: property name __proto__ appears more than once in object literal
- SyntaxError: getter and setter for private name #x should either be both static or non-static
- SyntaxError: functions cannot be labelled
- RangeError: form must be one of \'NFC\', \'NFD\', \'NFKC\', or \'NFKD\'
- TypeError: can\'t access/set private field or method: object is not the right class
- SyntaxError: getter functions must have no arguments
- SyntaxError: Unexpected \'#\' used outside of class body
- TypeError: setting getter-only property "x"
- SyntaxError: identifier starts immediately after numeric literal
- SyntaxError: illegal character
- SyntaxError: import declarations may only appear at top level of a module
- TypeError: cannot use \'in\' operator to search for \'x\' in \'y\'
- RangeError: invalid array length
- SyntaxError: invalid BigInt syntax
- SyntaxError: invalid assignment left-hand side
- TypeError: invalid assignment to const "x"
- TypeError: derived class constructor returned invalid value x
- RangeError: invalid date
- SyntaxError: a declaration in the head of a for-of loop can\'t have an initializer
- SyntaxError: for-in loop head declarations may not have initializers
- TypeError: invalid \'instanceof\' operand \'x\'
- TypeError: \'x\' is not iterable
- SyntaxError: JSON.parse: bad parsing
- TypeError: WeakSet key/WeakMap value \'x\' must be an object or an unregistered symbol
- SyntaxError: label not found
- URIError: malformed URI sequence
- SyntaxError: missing ] after element list
- SyntaxError: missing : after property id
- SyntaxError: missing } after property list
- SyntaxError: missing } after function body
- SyntaxError: missing formal parameter
- SyntaxError: missing = in const declaration
- SyntaxError: missing name after . operator
- SyntaxError: missing ) after argument list
- SyntaxError: missing ) after condition
- RangeError: repeat count must be non-negative
- TypeError: More arguments needed
- TypeError: "x" is not a non-null object
- TypeError: null/undefined has no properties
- SyntaxError: missing variable name
- TypeError: can\'t delete non-configurable array element
- TypeError: "x" is not a constructor
- RangeError: argument is not a valid code point
- TypeError: "x" is not a function
- SyntaxError: parameter after rest parameter
- RangeError: precision is out of range
- TypeError: getting private setter-only property
- AggregateError: No Promise in Promise.any was resolved
- TypeError: Initializing an object twice is an error with private fields/methods
- Error: Permission denied to access property "x"
- TypeError: Reduce of empty array with no initial value
- TypeError: "x" is read-only
- SyntaxError: redeclaration of formal parameter "x"
- SyntaxError: character class escape cannot be used in class range in regular expression
- SyntaxError: \ at end of pattern
- SyntaxError: duplicate capture group name in regular expression
- SyntaxError: invalid capture group name in regular expression
- SyntaxError: incomplete quantifier in regular expression
- SyntaxError: invalid character in class in regular expression
- SyntaxError: invalid class set operation in regular expression
- SyntaxError: invalid decimal escape in regular expression
- SyntaxError: invalid identity escape in regular expression
- SyntaxError: invalid regexp group
- SyntaxError: invalid property name in regular expression
- SyntaxError: invalid named capture reference in regular expression
- SyntaxError: invalid range in character class
- SyntaxError: invalid unicode escape in regular expression
- SyntaxError: negated character class with strings in regular expression
- SyntaxError: numbers out of order in {} quantifier.
- SyntaxError: nothing to repeat
- SyntaxError: raw bracket is not allowed in regular expression with unicode flag
- SyntaxError: rest parameter may not have a default
- TypeError: matchAll/replaceAll must be called with a global RegExp
- SyntaxError: "x" is a reserved identifier
- RangeError: repeat count must be less than infinity
- Warning: unreachable code after return statement
- SyntaxError: setter functions must have one argument
- SyntaxError: "use strict" not allowed in function with non-simple parameters
- SyntaxError: string literal contains an unescaped line break
- ReferenceError: must call super constructor before using \'this\' in derived class constructor
- SyntaxError: reference to undeclared private field or method #x
- InternalError: too much recursion
- ReferenceError: super() called twice in derived class constructor
- SyntaxError: Unexpected token
- ReferenceError: assignment to undeclared variable "x"
- TypeError: "x" is (not) "y"
- SyntaxError: function statement requires a name
- SyntaxError: unparenthesized unary expression can\'t appear on the left-hand side of \'**\'
- get
- Method definitions
- set
- Rest parameters
- arguments.length
- arguments.callee
- arguments[Symbol.iterator]()
- async function*
- await using
- Block statement
- break
- class
- continue
- do...while
- debugger
- export
- Empty statement
- Expression statement
- for
- for await...of
- function
- function*
- Labeled statement
- return
- throw
- while
- using
- Import attributes
- with
- Assignment (=)
- Addition (+)
- async function expression
- Addition assignment (+=)
- async function* expression
- Bitwise AND assignment (&=)
- Bitwise AND (&)
- Bitwise NOT (~)
- Bitwise OR (|)
- Bitwise OR assignment (|=)
- class expression
- Bitwise XOR (^)
- Bitwise XOR assignment (^=)
- Comma operator (,)
- Decrement (--)
- Destructuring
- Division (/)
- Equality (==)
- Exponentiation assignment (**=)
- Division assignment (/=)
- Exponentiation (**)
- function* expression
- Greater than or equal (>=)
- Greater than (>)
- Grouping operator ( )
- import()
- Increment (++)
- in
- Inequality (!=)
- instanceof
- Left shift (<<)
- Left shift assignment (<<=)
- Less than (<)
- Less than or equal (<=)
- Logical AND assignment (&&=)
- Logical NOT (!)
- Logical OR assignment (||=)
- Multiplication (*)
- Multiplication assignment (*=)
- new.target
- Nullish coalescing assignment (??=)
- Operator precedence
- Remainder (%)
- Remainder assignment (%=)
- Right shift (>>)
- Right shift assignment (>>=)
- Strict equality (===)
- Subtraction (-)
- Subtraction assignment (-=)
- Strict inequality (!==)
- super
- Unary negation (-)
- Unary plus (+)
- Unsigned right shift assignment (>>>=)
- Unsigned right shift (>>>)
- void operator
- yield
- yield*
- import.meta.resolve()
- import.meta
- decodeURI()
- decodeURIComponent()
- encodeURI()
- escape()
- eval()
- globalThis
- isFinite()
- parseFloat()
- unescape()
- AggregateError
- Array() constructor
- Array.prototype.copyWithin()
- Array.prototype.entries()
- Array.prototype.fill()
- Array.prototype.findLastIndex()
- Array.prototype.findLast()
- Array.fromAsync()
- Array.prototype.keys()
- Array.prototype.lastIndexOf()
- Array.of()
- Array.prototype.reduceRight()
- Array.prototype[Symbol.iterator]()
- Array[Symbol.species]
- Array.prototype[Symbol.unscopables]
- Array.prototype.toLocaleString()
- Array.prototype.toSorted()
- Array.prototype.toReversed()
- Array.prototype.toSpliced()
- Array.prototype.toString()
- Array.prototype.values()
- AsyncFunction
- Array.prototype.with()
- ArrayBuffer() constructor
- ArrayBuffer.prototype.byteLength
- ArrayBuffer.isView()
- ArrayBuffer.prototype.maxByteLength
- ArrayBuffer.prototype.resizable
- ArrayBuffer.prototype.resize()
- ArrayBuffer.prototype.slice()
- ArrayBuffer[Symbol.species]
- ArrayBuffer.prototype.transfer()
- ArrayBuffer.prototype.transferToFixedLength()
- AsyncDisposableStack
- AsyncGenerator
- AsyncGeneratorFunction
- AsyncIterator
- BigInt.asUintN()
- BigInt.asIntN()
- BigInt() constructor
- BigInt.prototype.toLocaleString()
- BigInt.prototype.toString()
- Atomics
- BigInt.prototype.valueOf()
- BigUint64Array
- BigInt64Array
- Boolean() constructor
- Boolean.prototype.toString()
- Boolean.prototype.valueOf()
- DataView
- Date.prototype.getDate()
- Date.prototype.getDay()
- Date.prototype.getHours()
- Date.prototype.getFullYear()
- Date.prototype.getMinutes()
- Date.prototype.getMilliseconds()
- Date.prototype.getMonth()
- Date.prototype.getSeconds()
- Date.prototype.getTime()
- Date.prototype.getTimezoneOffset()
- Date.prototype.getUTCDate()
- Date.prototype.getUTCDay()
- Date.prototype.getUTCFullYear()
- Date.prototype.getUTCHours()
- Date.prototype.getUTCMilliseconds()
- Date.prototype.getUTCMinutes()
- Date.prototype.getUTCMonth()
- Date.prototype.getUTCSeconds()
- Date.prototype.getYear()
- Date.prototype.setFullYear()
- Date.prototype.setMilliseconds()
- Date.prototype.setDate()
- Date.prototype.setHours()
- Date.prototype.setMinutes()
- Date.prototype.setMonth()
- Date.prototype.setSeconds()
- Date.prototype.setTime()
- Date.prototype.setUTCDate()
- Date.prototype.setUTCHours()
- Date.prototype.setUTCFullYear()
- Date.prototype.setUTCMilliseconds()
- Date.prototype.setUTCMinutes()
- Date.prototype.setUTCMonth()
- Date.prototype.setUTCSeconds()
- Date.prototype[Symbol.toPrimitive]()
- Date.prototype.setYear()
- Date.prototype.toDateString()
- Date.prototype.toJSON()
- Date.prototype.toString()
- Date.prototype.toLocaleTimeString()
- Date.prototype.toTemporalInstant()
- Date.prototype.toTimeString()
- Date.UTC()
- Date.prototype.toUTCString()
- Date.prototype.valueOf()
- DisposableStack
- Error.captureStackTrace()
- Error() constructor
- Error: cause
- Error: columnNumber
- Error: fileName
- Error.isError()
- Error: lineNumber
- Error.prototype.name
- Error: message
- Error.prototype.stack
- Error.stackTraceLimit
- EvalError
- Error.prototype.toString()
- FinalizationRegistry
- Float16Array
- Float32Array
- Float64Array
- Generator
- Function.prototype.apply()
- Function.prototype.bind()
- Function.prototype.arguments
- Function.prototype.call()
- Function: displayName
- Function.prototype.caller
- Function() constructor
- Function: length
- Function: name
- Function: prototype
- Function.prototype[Symbol.hasInstance]()
- Function.prototype.toString()
- GeneratorFunction
- Int32Array
- Int16Array
- Int8Array
- InternalError
- JSON.isRawJSON()
- JSON.rawJSON()
- Iterator.prototype.drop()
- Iterator
- Map.prototype.delete()
- Map.prototype.clear()
- Map.prototype.entries()
- Map.prototype.get()
- Map.prototype.forEach()
- Map.prototype.getOrInsertComputed()
- Map.prototype.getOrInsert()
- Map.groupBy()
- Map.prototype.keys()
- Map.prototype.has()
- Map() constructor
- Map.prototype.size
- Map.prototype.set()
- Map.prototype[Symbol.iterator]()
- Map.prototype.values()
- Map[Symbol.species]
- Math.f16round()
- Math.sumPrecise()
- Number.EPSILON
- Number.isFinite()
- Number.isInteger()
- Number.isNaN()
- Number.isSafeInteger()
- Number.MAX_SAFE_INTEGER
- Number.MAX_VALUE
- Number.MIN_VALUE
- Number.MIN_SAFE_INTEGER
- Number.NaN
- Number.NEGATIVE_INFINITY
- Number.parseFloat()
- Number() constructor
- Number.parseInt()
- Number.POSITIVE_INFINITY
- Number.prototype.toFixed()
- Number.prototype.toExponential()
- Number.prototype.toLocaleString()
- Number.prototype.toPrecision()
- Number.prototype.toString()
- Object.prototype.__defineGetter__()
- Number.prototype.valueOf()
- Object.prototype.__defineSetter__()
- Object.prototype.__lookupGetter__()
- Object.prototype.__lookupSetter__()
- Object.defineProperties()
- Object.getOwnPropertyDescriptor()
- Object.getOwnPropertyDescriptors()
- Object.getOwnPropertySymbols()
- Object.getPrototypeOf()
- Object.groupBy()
- Object.isExtensible()
- Object.isFrozen()
- Object.prototype.isPrototypeOf()
- Object.isSealed()
- Object() constructor
- Object.preventExtensions()
- Object.prototype.propertyIsEnumerable()
- Object.prototype.__proto__
- Object.seal()
- Object.prototype.toLocaleString()
- Object.setPrototypeOf()
- Promise.allSettled()
- Promise.any()
- Promise.prototype.catch()
- Promise.prototype.finally()
- Promise.reject()
- Promise.race()
- Promise[Symbol.species]
- Promise.try()
- RangeError
- ReferenceError
- Reflect
- SharedArrayBuffer
- RegExp.prototype.compile()
- RegExp.prototype.dotAll
- RegExp.escape()
- RegExp.prototype.flags
- RegExp.prototype.global
- RegExp.prototype.hasIndices
- RegExp.input ($_)
- RegExp.prototype.ignoreCase
- RegExp.lastMatch ({{ListSubpages("", 1, 0, 1)}}amp;)
- RegExp.lastParen ($+)
- RegExp.leftContext ($\`)
- RegExp.$1, …, RegExp.$9
- RegExp() constructor
- RegExp.prototype.multiline
- RegExp.rightContext ($\')
- RegExp.prototype.source
- RegExp.prototype.sticky
- RegExp.prototype[Symbol.match]()
- RegExp.prototype[Symbol.matchAll]()
- RegExp.prototype[Symbol.replace]()
- RegExp.prototype[Symbol.search]()
- RegExp[Symbol.species]
- RegExp.prototype[Symbol.split]()
- RegExp.prototype.toString()
- RegExp.prototype.unicode
- RegExp.prototype.unicodeSets
- Set.prototype.add()
- Set.prototype.delete()
- Set.prototype.clear()
- Set.prototype.entries()
- Set.prototype.has()
- Set.prototype.forEach()
- Set() constructor
- Set.prototype.size
- Set.prototype.keys()
- Set[Symbol.species]
- Set.prototype[Symbol.iterator]()
- Set.prototype.values()
- SuppressedError
- SyntaxError
- String.prototype.isWellFormed()
- String.prototype.toWellFormed()
- Symbol.prototype.description
- Symbol.dispose
- Symbol.asyncDispose
- Symbol.hasInstance
- Symbol.asyncIterator
- Symbol.isConcatSpreadable
- Symbol.iterator
- Symbol.for()
- Symbol.match
- Symbol.keyFor()
- Symbol.matchAll
- Symbol.replace
- Symbol.species
- Symbol.search
- Symbol.split
- Symbol() constructor
- Symbol.toPrimitive
- Symbol.prototype.toString()
- Symbol.prototype[Symbol.toPrimitive]()
- Symbol.toStringTag
- Symbol.prototype.valueOf()
- Symbol.unscopables
- TypeError() constructor
- Uint16Array
- Uint32Array
- Uint8ClampedArray
- TypedArray
- Uint8Array
- URIError
- WeakRef
- WeakMap
- WeakSet
- Proxy.revocable()
- Proxy() constructor
- Temporal.Duration
- Temporal
- Intl.getCanonicalLocales()
- Intl.supportedValuesOf()
- Intl.DateTimeFormat
- Intl.DisplayNames
- Intl.DurationFormat
- Intl.ListFormat
- Intl.Locale
- Intl.NumberFormat.prototype.format()
- Intl.NumberFormat.prototype.formatRange()
- Intl.NumberFormat.prototype.formatToParts()
- Intl.NumberFormat() constructor
- Intl.NumberFormat.prototype.formatRangeToParts()
- Intl.NumberFormat.prototype.resolvedOptions()
- Intl.NumberFormat.supportedLocalesOf()
- Intl.RelativeTimeFormat
- Intl.PluralRules
- Intl.Collator
- Intl.Segmenter() constructor
- Intl.Segmenter
- SVG guides
- SVG tutorials
- SVG element reference
- SVG reference
- CSS – Каскадні списки стилів
- HTML – мова розмітки гіпертексту
- JavaScript
- SVG: масштабована векторна графіка
Відкритий веб надає дивовижні можливості для розробників. Щоб скористатися усіма перевагами цих технологій, потрібно розуміти, як їх застосовувати. Нижче наведено посилання на документацію про різні вебтехнології.
Документація для веброзробників
- Посібник веброзробника
Посібник веброзробника пропонує корисні матеріали, які допоможуть вам використовувати вебтехнології для виконання того, що ви хочете або повинні зробити.
- Підручники для веброзробників
Набір підручників, які крок за кроком проведуть вас через вивчення HTML, CSS, JavaScript й API Вебу.
- Доступність
Про те, як зробити використання вебсайтів можливим для якомога більшої кількості людей, навіть якщо можливості цих людей певним чином обмежено.
- Ефективність
Про те, як зробити вміст якомога доступнішим та інтерактивнішим, якомога швидше.
- Безпека
Захист користувачів від витоку даних та крадіжки даних, атак сторонніми каналами, а також міжсайтового програмування, ін'єкцій вмісту та перехоплення клацань.
Довідник з вебтехнологій
- API Вебу
API програмування на JavaScript, які можна використовувати для створення застосунків у Вебі.
- HTML
HTML надає основні (базові) цеглини для структурування вебдокументів та вебзастосунків.
- CSS
Каскадні списки стилів використовуються для опису зовнішнього вигляду вебдокументів та вебзастосунків.
- JavaScript
JavaScript – це рідна мова програмування Вебу.
- WebAssembly
WebAssembly дає змогу програмам, написаним на C, C++, Rust, Swift, C#, Go та інших мовах, працювати у Вебі.
- Події
Події – це те, для реагування на що створюються вебзастосунки; наприклад, коли вебсторінка завершує своє завантаження, або коли користувач щось обирає, натискає клавішу, змінює розмір вікна, подає форму чи призупиняє відео.
- HTTP
HTTP – це фундаментальний протокол Інтернету для отримання документів, списків стилів, сценаріїв, зображень, відео, шрифтів та інших ресурсів крізь Веб – а також для надсилання даних назад на вебсервери.
- Медіа
Формати, кодеки, протоколи, API та техніки для вбудування та потокового відтворення відео, аудіо та зображень у вебдокументах і вебзастосунках.
- SVG
Масштабовна векторна графіка дає змогу описувати зображення, що плавно масштабуються до будь-якого розміру.
- MathML
MathML дає змогу показувати складні математичні формули у Вебі.
- Вебкомпоненти
Вебкомпоненти – це елементи, які можна самотужки визначити та багаторазово використовувати у вебзастосунках.
- WebDriver
WebDriver – це механізм автоматизації браузерів для віддаленого керування браузером шляхом імітування дій справжньої людини, що ним користується. Широко використовується для тестування вебзастосунків у різних браузерах.
- Веброзширення
Веброзширення – спосіб надати користувачам у їхніх браузерах розширені можливості, наприклад, блокування реклами та іншого вмісту, налаштування вигляду сторінок та інше.
- Декларації вебзастосунків
Декларації вебзастосунків дають користувачам змогу встановлювати вебзастосунки на домашні екрани своїх пристроїв, з наперед визначеними аспектами штибу вертикального чи горизонтального орієнтування екрана, режиму відображення (наприклад, повноекранного) тощо.
- Поступові вебзастосунки (PWA)
Поступові вебзастосунки пропонують користувацький досвід, подібний до нативних мобільних застосунків.
Документація інструментів розробника
- Інструменти розробника Firefox
Документація набору інструментів розробника, вбудованого в Firefox.
- Chrome DevTools
Документація набору інструментів розробника, вбудованого в Chrome.
- Вебінспектор Safari
Документація набору інструментів веброзробника, вбудованого в Safari.
- Edge DevTools
Документація набору інструментів веброзробника, вбудованого в Edge.