querySelectorAll Method
The querySelectorAll method finds all the elements on the page that match the specified selector, and it returns a collection, meaning a set of these elements.
// Finds all paragraphs on the page
let elements = document. querySelectorAll ('p');
Collection
A collection can be saved in a variable. The easiest way to find out what elements are contained in a collection is to display it in the console:
// Displays the collection in the console
console.log(elements);
The collection looks like a list in the console in which the elements are presented as a comma-separated list. The entire list is wrapped in square brackets, and only the tag and class, for example, are specified for the elements. To display the elements in the same way as in the markup, you need to expand the collection by clicking on the triangle arrow on the left.
[p.card__text, p, p, p]
[p.card__text, p, p]
<p class="card__text">Let’s make ice cream!</p>
<p>St. Petersburg</p>
<p>mail@htmlacademy.ru</p>
You can address the collection element by index. The index is the serial number of the element in the collection. The serial number increases starting from zero, so the first element has an index of 0 and the second has an index of 1. Indices are written in square brackets after the collection name:
console.log(elements[0]); // Displays the first element in the collection
console.log(elements[1]); // Displays the second element in the collection
Data Attributes
You can create your own attributes in HTML. The names of these attributes start with the data- prefix followed by any word that is selected by the developer.
<div data-cat-name="Muffin">
To get the value of a data attribute in JavaScript, use the dataset property followed by the attribute name without the data- prefix:
element.dataset.attributeNameWithoutPrefix
If the attribute name consists of several words that use hyphens, then in JavaScript it is written in camelCase: the hyphens are removed, and each word is capitalized except for the first one.
let element = document.querySelector('div');
console.log(element.dataset.catName); // Displays: Muffin
for of Loop
A loop is a statement that allows you to execute code several times. The for of loop will execute the code in the curly braces as many times as there are elements in the collection indicated in parentheses. Each such repetition is called an iteration.
for (of collection variable) {
// Code that must be executed several times
}
When a loop is created in parentheses, you must also specify a variable. Usually in order to do this, a new variable is declared, and it is used only inside the loop. At each iteration, JavaScript will automatically write the next element in the collection to this variable.
let elements = document.querySelectorAll('p'); // Find all paragraphs
for (let element of elements) { // Create a loop and variable
console.log(element); // Display the elements in the console
}
The for of loop is complete when the elements in the collection are finished. After that, JavaScript will proceed to execute the instructions that come after the loop.
The oninput Event Handler
The oninput event handler makes it possible to execute instructions in curly braces every time the value in the input field changes. Either adding or deleting characters is considered a change.
// Find an input field
let textarea = document.querySelector('textarea');
// Add an event handler
textarea.oninput = function () {
// Display the data from the input field
console.log(textarea.value);
};
length Property
You can determine the string length using the length property. The value of this property is equal to the number of characters in the string. Characters are more than just letters and numbers. They also include white spaces and line breaks.
let text = 'I love JavaScript';
console.log(text.length); // Displays: 17
let textarea = document.querySelector('textarea');
console.log(textarea.value); // Displays: Muffin
console.log(textarea.value.length); // Displays: 6
The Comparison Operator >
The comparison operator > (“greater than”) compares two numbers and returns the Boolean value true if the the left one is greater than the right one and false in all other cases:
console.log(3 > 2); // Returns: true
console.log(1 > 2); // Returns: false
console.log(2 > 2); // Returns: false
The disabled Property
You can lock and unlock the button in JavaScript by assigning Boolean values to the disabled property for this button. If the true value is assigned, then the button is locked, whereas if it is assigned false, then the button is unlocked.
let button = document.querySelector('button');
// Locks the button
button.disabled = true;
// Unlocks the button
button.disabled = false;
Continue
<!DOCTYPE html><html lang="en" class="no-js"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1"><script>var b=document.documentElement.classList;b.remove('no-js');if(!window.Promise||!window.sessionStorage||!!sessionStorage.getItem('muller.v2')){b.add('muller')}</script><link rel="dns-prefetch" href="https://assets.htmlacademy.org"><script async src="https://www.googletagmanager.com/gtag/js?id=G-MXPCRXM48C"></script><script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-MXPCRXM48C');
</script><script type="text/javascript">
(function(e,t){var n=e.amplitude||{_q:[],_iq:{}};var r=t.createElement("script")
;r.type="text/javascript"
;r.integrity="sha384-d/yhnowERvm+7eCU79T/bYjOiMmq4F11ElWYLmt0ktvYEVgqLDazh4+gW9CKMpYW"
;r.crossOrigin="anonymous";r.async=true
;r.src="https://cdn.amplitude.com/libs/amplitude-5.2.2-min.gz.js"
;r.onload=function(){if(!e.amplitude.runQueuedFunctions){
console.log("[Amplitude] Error: could not load SDK")}}
;var i=t.getElementsByTagName("script")[0];i.parentNode.insertBefore(r,i)
;function s(e,t){e.prototype[t]=function(){
this._q.push([t].concat(Array.prototype.slice.call(arguments,0)));return this}}
var o=function(){this._q=[];return this}
;var a=["add","append","clearAll","prepend","set","setOnce","unset"]
;for(var u=0;u<a.length;u++){s(o,a[u])}n.Identify=o;var c=function(){this._q=[]
;return this}
;var l=["setProductId","setQuantity","setPrice","setRevenueType","setEventProperties"]
;for(var p=0;p<l.length;p++){s(c,l[p])}n.Revenue=c
;var d=["init","logEvent","logRevenue","setUserId","setUserProperties","setOptOut","setVersionName","setDomain","setDeviceId","setGlobalUserProperties","identify","clearUserProperties","setGroup","logRevenueV2","regenerateDeviceId","groupIdentify","onInit","logEventWithTimestamp","logEventWithGroups","setSessionId","resetSessionId"]
;function v(e){function t(t){e[t]=function(){
e._q.push([t].concat(Array.prototype.slice.call(arguments,0)))}}
for(var n=0;n<d.length;n++){t(d[n])}}v(n);n.getInstance=function(e){
e=(!e||e.length===0?"$default_instance":e).toLowerCase()
;if(!n._iq.hasOwnProperty(e)){n._iq[e]={_q:[]};v(n._iq[e])}return n._iq[e]}
;e.amplitude=n})(window,document);
amplitude.getInstance().init("df11525b6880a3c5e2af14f9b6238408", null,{
includeUtm: true,
includeGclid: true,
includeReferrer: true,
deviceIdFromUrlParam: true
}, function (instance) {
window.amplitudeLoaded = true;
});
</script><link rel="stylesheet" href="https://assets.htmlacademy.org/css/core.v284.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/profile.v236.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course.v246.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course-interface-light.v20.css"><link rel="stylesheet" href="https://assets.htmlacademy.org/css/course-interface-en.v2.css"><script src="https://assets.htmlacademy.org/js/sentry.js" data-sentry="3774884cc81746ed84c0ba7c5cd4ac7b" data-project="26" data-version="2"></script><link rel="stylesheet" href="/css/custom.css"><link rel="stylesheet" href="/css/cookies.css"><link rel="preload" as="script" href="https://assets.htmlacademy.org/js/general.v274.js"><title>Summary of “Element Collections and Properties” — Element collections and properties — HTML Academy</title><meta name="csrf-token" content="36764caf322823086fca37a7326b9bd2a54"><meta property="og:type" content="website"><meta property="og:site_name" content="HTML Academy"><meta name="twitter:url" property="og:url" content="https://htmlacademy.org"><meta name="twitter:title" property="og:title" content="Interactive online courses HTML Academy"><meta name="twitter:description" property="og:description" content="Together we’ll learn how to work with real code, solve true-to-life problems, use cutting edge technologies. Minimum of boring theory and lots of practical tasks."><meta name="twitter:image" property="og:image" content="https://htmlacademy.org/og/htmlacademy.png"><meta name="twitter:card" content="summary_large_image"><link rel="canonical" href="https://htmlacademy.org/courses/javascript-basics/element-collections-properties/summary"><meta name="theme-color" content="#2f358f"></head><body class="course-interface course-interface--light course-interface--full" data-base="/assets/courses/20/"><header class="page-header page-header--course"><div class="page-header__inner"><div class="page-header__top"><a class="page-header__logo" href="/" aria-label="HTML Academy Home"><img src="https://assets.htmlacademy.org/img/logo--small.svg?cs=1218aec0be4a5f23db79ad29a14e30f7f9fb9a25" width="24" height="36" alt="HTML Academy"></a><nav class="main-nav main-nav--mini" role="navigation"><div class="main-nav__course-nav"><a class="main-nav__course-item main-nav__course-button main-nav__course-button--prev" href="/courses/javascript-basics/element-collections-properties/counter-reset">Reset the character counter to zero</a><div class="main-nav__course-item main-nav__course-list main-nav__course-list--collapsed"><b class="main-nav__course-title">Element collections and properties</b><span class="main-nav__course-stat">16/17</span><div class="main-nav__course-contents"><a class="main-nav__course-contents-link" href="/courses/javascript-basics/element-collections-properties">Back to the list of tasks</a><ul class="main-nav__course-contents-list"><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/check-tooltips">1. Check the pop-up tooltips</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/queryselectorall-vs-collection">2. The querySelectorAll Method and Collections</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/collection-elements-index">3. Address the elements in the collection by index</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/add-handlers">4. Add handlers to both buttons</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/data-attribute-value">5. Get the value of the data attribute</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/tooltip-text-output">6. Output the tooltip text to the page</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/include-script">7. Include the script in another page</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/for-of-loop">8. The for of Loop</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/handler-in-loop">9. Add the handler using the loop</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/oninput-event-handler">10. The oninput Event Handler</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/length-property">11. The Length Property, Calculating the String Length</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/numbers-compare">12. Compare the numbers</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/disabled-property">13. The disabled Property, Locking the Button</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/add-else-branch">14. Add the branch else</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/counter-reset">15. Reset the character counter to zero</a></li><li class="main-nav__course-contents-item main-nav__course-contents-item--current"><a href="/courses/javascript-basics/element-collections-properties/summary">16. Summary of “Element Collections and Properties”</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/element-collections-properties/virtual-keyboard">17. Test: Virtual keyboard</a></li></ul></div></div><a class="main-nav__course-item main-nav__course-button main-nav__course-button--next" href="/courses/javascript-basics/element-collections-properties/virtual-keyboard">Test: Virtual keyboard</a></div><ul class="main-nav__list main-nav__list--user main-nav__list--user-guest"><li class="main-nav__item" itemprop="name"><a class="main-nav__link" href="/signup?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" title="Sign up" data-modal="open" data-value="register" itemprop="url"><span class="main-nav__icon" aria-hidden="true"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#user"></use></svg></span>Sign up</a></li><li class="main-nav__item main-nav__item--login" itemprop="name"><a class="main-nav__link" href="/login?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" title="Log in" data-modal="open" data-value="login" itemprop="url"><span class="main-nav__icon" aria-hidden="true"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#login"></use></svg></span>Log in</a></li></ul></nav></div></div></header><main class="course-container"><div class="course-theory"><div class="course-theory__inner"><section class="course-theory__content"><h1 class="course-theory__content-heading course-theory__content-heading--synopsis">Summary of “Element Collections and Properties”</h1><div class="course-theory__content-text"><h2>querySelectorAll Method</h2><p>The <code>querySelectorAll</code> method finds all the elements on the page that match the specified selector, and it returns a <b>collection</b>, meaning a set of these elements.</p><pre><code>// Finds all paragraphs on the page
let elements = document. <mark> querySelectorAll </mark> ('p');</code></pre><h2>Collection</h2><p>A collection can be saved in a variable. The easiest way to find out what elements are contained in a collection is to display it in the console:</p><pre><code>// Displays the collection in the console
console.log(<mark>elements</mark>);</code></pre><p>The collection looks like a list in the console in which the elements are presented as a comma-separated list. The entire list is wrapped in square brackets, and only the tag and class, for example, are specified for the elements. To display the elements in the same way as in the markup, you need to expand the collection by clicking on the triangle arrow on the left.</p><div class="console__line console__line--log" style="border-top: 1px solid #d5d5d5; margin-bottom: 1em;"><div class="console__line-collapse-item"><div class="console__line-collapse-item-main-content">[p.card__text, p, p, p] <span class="console__line-type"></span></div><div class="console__line-collapse-item-additional-content">[p.card__text, p, p] <span class="console__line-type"></span><div class="console__line-collapse-item console__line-collapse-item--collapsed"><p class="card__text">Let’s make ice cream!</p> <span class="console__line-type"></span></div><div class="console__line-collapse-item console__line-collapse-item--collapsed"><p>St. Petersburg</p> <span class="console__line-type"></span></div><div class="console__line-collapse-item console__line-collapse-item--collapsed"><p>mail@htmlacademy.ru</p> <span class="console__line-type"></span></div></div></div></div><p>You can address the collection element by index. The <b>index</b> is the serial number of the element in the collection. The serial number increases starting from zero, so the first element has an index of 0 and the second has an index of 1. Indices are written in square brackets after the collection name:</p><pre><code>console.log(elements<mark>[0]</mark>); // Displays the first element in the collection
console.log(elements<mark>[1]</mark>); // Displays the second element in the collection</code></pre><h2>Data Attributes</h2><p>You can create your own attributes in HTML. The names of these attributes start with the <code class="nowrap">data-</code> prefix followed by any word that is selected by the developer.</p><pre><code><div <mark>data-cat-name</mark>="Muffin"></code></pre><p>To get the value of a data attribute in JavaScript, use the <code>dataset</code> property followed by the attribute name without the <code class="nowrap">data-</code> prefix:</p><pre><code>element.<mark>dataset</mark>.attributeNameWithoutPrefix</code></pre><p>If the attribute name consists of several words that use hyphens, then in JavaScript it is written in <i>camelCase</i>: the hyphens are removed, and each word is capitalized except for the first one.</p><pre><code>let element = document.querySelector('div');
console.log(<mark>element.dataset.catName</mark>); // Displays: Muffin</code></pre><h2>for of Loop</h2><p>A loop is a statement that allows you to execute code several times. The <code class="nowrap">for of</code> loop will execute the code in the curly braces as many times as there are elements in the collection indicated in parentheses. Each such repetition is called an <i>iteration</i>.</p><pre><code><mark>for</mark> (<mark>of</mark> collection variable) {
// Code that must be executed several times
}</code></pre><p>When a loop is created in parentheses, you must also specify a variable. Usually in order to do this, a new variable is declared, and it is used only inside the loop. At each iteration, JavaScript will automatically write the next element in the collection to this variable.</p><pre><code>let elements = document.querySelectorAll('p'); // Find all paragraphs
for (let <mark>element</mark> of elements) { // Create a loop and variable
console.log(<mark>element</mark>); // Display the elements in the console
}</code></pre><p>The <code class="nowrap">for of</code> loop is complete when the elements in the collection are finished. After that, JavaScript will proceed to execute the instructions that come after the loop.</p><h2>The oninput Event Handler</h2><p>The <code>oninput</code> event handler makes it possible to execute instructions in curly braces every time the value in the input field changes. Either adding or deleting characters is considered a change.</p><pre><code>// Find an input field
let textarea = document.querySelector('textarea');
// Add an event handler
textarea.<mark>oninput</mark> = function () {
// Display the data from the input field
console.log(textarea.value);
};</code></pre><h2>length Property</h2><p>You can determine the string length using the <code>length</code> property. The value of this property is equal to the number of characters in the string. Characters are more than just letters and numbers. They also include white spaces and line breaks.</p><pre><code>let text = 'I love JavaScript';
console.log(text.<mark>length</mark>); // Displays: 17
let textarea = document.querySelector('textarea');
console.log(textarea.value); // Displays: Muffin
console.log(textarea.value.<mark>length</mark>); // Displays: 6</code></pre><h2>The Comparison Operator ></h2><p>The comparison operator <code>></code> (“greater than”) compares two numbers and returns the Boolean value <code>true</code> if the the left one is greater than the right one and <code>false</code> in all other cases:</p><pre><code>console.log(3 <mark>></mark> 2); // Returns: true
console.log(1 <mark>></mark> 2); // Returns: false
console.log(2 <mark>></mark> 2); // Returns: false</code></pre><h2>The disabled Property</h2><p>You can lock and unlock the button in JavaScript by assigning Boolean values to the <code>disabled</code> property for this button. If the <code>true</code> value is assigned, then the button is locked, whereas if it is assigned <code>false</code>, then the button is unlocked.</p><pre><code>let button = document.querySelector('button');
// Locks the button
button.<mark>disabled = true</mark>;
// Unlocks the button
button.<mark>disabled = false</mark>;</code></pre><br><a class="button button--green button--large button--wide button--icon" href="/courses/javascript-basics/element-collections-properties/virtual-keyboard"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#icon-check-bold"></use></svg>
Continue
</a></div></section></div></div><script
src="https://assets.htmlacademy.org/scripts/courses-spa/htmlacademy-task.v43.js"
data-assets-path="https://assets.htmlacademy.org/scripts/courses-spa/"
data-task-type="theory"
data-lang="en"
></script><script>HtmlacademyTask.setup(function(){});</script></main><footer class="page-footer page-footer--tiny"><div class="page-footer__inner"><p><a href="/docs/cookies">Cookies</a> ∙
<a href="/docs/privacy">Privacy</a> ∙
<a href="/docs/agreement">License Agreement</a> ∙
<a href="/docs/about">About</a> ∙
<a href="/contacts">Contacts</a> ∙
© HTML Academy OÜ, 2019−2026
</p><div class="page-footer__financial"><img src="https://assets.htmlacademy.org/img/visa-white.svg?cs=96e54ec8c587db9d4b1d8d328ffd87c2ebfd9555" alt="VISA" title="VISA" width="35" height="35"><img src="https://assets.htmlacademy.org/img/mastercard-horizontal.v2.svg" alt="Mastercard" title="Mastercard" width="35" height="35"></div></div></footer><div class="modal"><div class="modal__inner"><div class="modal__wrapper js-login hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Log in</h4><ul class="modal__social"><li class="modal__social-link modal__social-link--fb"><a href="/login/fb?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" rel="nofollow" title="Log in via Facebook"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#facebook"></use></svg></a></li><li class="modal__social-link modal__social-link--google"><a href="/login/google?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" rel="nofollow" title="Log in via Google"><svg height="30" width="30" viewBox="0 0 512 512" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M457.732 216.625c2.628 14.041 4.063 28.743 4.063 44.098C461.796 380.688 381.481 466 260.204 466c-116.023 0-210-93.977-210-210s93.977-210 210-210c56.704 0 104.077 20.867 140.44 54.73l-59.204 59.197v-.135c-22.046-21.002-50-31.762-81.236-31.762-69.297 0-125.604 58.537-125.604 127.841 0 69.29 56.306 127.968 125.604 127.968 62.87 0 105.653-35.965 114.46-85.312h-114.46v-81.902h197.528z"/></svg></a></li></ul><div class="modal__or"><span>or</span></div><form class="modal__form form" action="/login?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" autocomplete="off" method="post" data-submit="o"><input type="hidden" name="csrf_name" value="csrf69aea5683584c"><input type="hidden" name="csrf_value" value="88978557ee1ed3335882653ce98a3474"><div class="form__group"><label class="sr-only" for="login-email">Email</label><input class="field field--text field--full-width" type="email" name="email" placeholder="Email" value="" id="login-email"></div><div class="form__group"><label class="sr-only" for="login-password">Password</label><input class="field field--text field--full-width ym-disable-keys" type="password" name="password" placeholder="Password" id="login-password"></div><input class="button button--full-width" type="submit" data-submit-text="Logging in…" value="Log in"></form><p class="modal__forgot-password"><a href="/recover" data-modal="open" data-value="recover">Forgot your password?</a></p><a class="modal__bottom-link" href="/signup" data-modal="open" data-value="register">Sign up</a></div><div class="modal__wrapper js-register hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Sign up</h4><ul class="modal__social"><li class="modal__social-link modal__social-link--fb"><a href="/login/fb?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" rel="nofollow" title="Log in via Facebook"><svg aria-hidden="true"><use xlink:href="/img/sprites/general.svg#facebook"></use></svg></a></li><li class="modal__social-link modal__social-link--google"><a href="/login/google?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" rel="nofollow" title="Log in via Google"><svg height="30" width="30" viewBox="0 0 512 512" xmlns="http://www.w3.org/2000/svg"><path fill="#ffffff" d="M457.732 216.625c2.628 14.041 4.063 28.743 4.063 44.098C461.796 380.688 381.481 466 260.204 466c-116.023 0-210-93.977-210-210s93.977-210 210-210c56.704 0 104.077 20.867 140.44 54.73l-59.204 59.197v-.135c-22.046-21.002-50-31.762-81.236-31.762-69.297 0-125.604 58.537-125.604 127.841 0 69.29 56.306 127.968 125.604 127.968 62.87 0 105.653-35.965 114.46-85.312h-114.46v-81.902h197.528z"/></svg></a></li></ul><div class="modal__or"><span>or</span></div><form class="modal__form form" action="/signup?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" autocomplete="off" method="post"><input type="hidden" name="csrf_name" value="csrf69aea5683584c"><input type="hidden" name="csrf_value" value="88978557ee1ed3335882653ce98a3474"><div class="form__group"><label class="sr-only" for="email">
Email
<span class="required"><span class="sr-only">Required field</span><span class="required__star">*</span></span></label><div class="form__group-fields"><input class="field field--text field--full-width" type="email" name="email" value="" id="email" required placeholder="Email"></div></div><div class="form__group"><label class="sr-only" for="password">
Password
<span class="required"><span class="sr-only">Required field</span><span class="required__star">*</span></span></label><div class="form__group-fields"><input class="field field--text field--full-width" type="password" name="password" value="" id="password" required placeholder="Password"></div></div><div class="form__group"><label class="checkbox"><input class="checkbox__input" type="checkbox" name="agreement" value="1" required><span class="checkbox__text"><span>By signing up, you agree to our <a href="/docs/agreement" target="_blank">License Agreement</a> and <a href="/docs/privacy" target="_blank">Privacy Policy</a>.</span></span></label></div><input class="button button--full-width" type="submit" data-submit-text="Signing up…" value="Sign up"></form><a class="modal__bottom-link" href="/login?redirect_url=%2Fcourses%2Fjavascript-basics%2Felement-collections-properties%2Fsummary" data-modal="open" data-value="login">Log in</a></div><div class="modal__wrapper modal__wrapper--no-btn-bottom js-recover hidden"><button class="modal__close icon-close" type="button" title="Close" data-modal="close"></button><h4 class="modal__header">Restore access</h4><p class="modal__text-accent">Have you forgotten your password or lost access to your profile? Enter your email connected to your profile and we will send you a link to restore access.</p><form class="modal__form form" action="/recover" autocomplete="off" method="post" data-submit="o"><input type="hidden" name="csrf_name" value="csrf69aea5683584c"><input type="hidden" name="csrf_value" value="88978557ee1ed3335882653ce98a3474"><div class="form__group"><label class="sr-only" for="recovery-email">Email</label><input class="field field--text field--full-width" type="email" name="email" placeholder="Email" value="" id="recovery-email"></div><script src='https://www.google.com/recaptcha/api.js'></script><div class="form__group"><div class="g-recaptcha" data-sitekey="6LetCTEqAAAAANROWtPzfC7Rfg9iIRiRt2k2FPn7"></div></div><input class="button button--full-width" type="submit" data-submit-text="Sending…" value="Send"></form><p class="modal__text">Forgot to connect your email to the profile? Email us and we’ll help.</p></div></div></div><script async src="https://assets.htmlacademy.org/js/general.v274.js" data-assets="https://assets.htmlacademy.org" data-require="toggle,navigation-courses,modal,form,nav"></script></body></html>