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