How to include several scripts on a page
In order to include yet another file with JavaScript code on a page, use the script tag again:
<body>
<script src="themes.js"></script>
<script src="likes.js"></script>
</body>
The browser processes the instructions sequentially: first in the first file, then in the second, as though they were located in a single place. Applications are often divided into several files, where usually one task corresponds to one file: for example, managing themes or subscribing to a newsletter.
Numbers
A variable can be assigned a value. Numbers do not need to be enclosed in quotation marks:
let number = 0;
To increase or decrease the number in JavaScript, you can use various entries:
// Fully entry
number = number + 2; // Variable value: 2
number = number - 2; // Variable value: 0
// Short entry
number += 2; // Variable value: 2
number -= 2; // Variable value: 0
// Increase the number by 1
number++; // Variable value: 1
// Decrease the number by 1
number--; // Variable value: 0
classList.contains method
The classList.contains method checks if an element has a class:
element.classList.contains('class');
The method will return true if the element has a class, and false if there is no class. The true and false values are called boolean values. There are only two such values.
Conditional statement
A conditional statement allows you to perform actions depending on a condition. A condition is an instruction that returns true or false. A conditional statement looks like the following:
if (condition) {
// Instructions that are executed if the condition is true
} else {
// Instructions that are executed if the condition is false
}
if
The condition is written in parentheses after the word if. After that, instructions that will be executed if the condition is true are written inside the curly braces. A condition is considered true if the statement inside the parentheses returns true.
else
The statement else tells JavaScript what to do if the condition is false. Instructions that should be executed if the condition returns false are written inside the curly braces after else.
The use of conditional statements in a script is also called branching, and the code inside the curly braces is called a branch.
append method
parent-element.append(element to be added);
The append method adds the element in parentheses to the end of the parent element. However, the contents of the parent element are not overwritten. You can use this method to add elements and strings of text.
createElement method
document.createElement('tag name');
To create a new element on the page where the script is included, you need to use the word document. Indicate the element to be created inside the quotation marks in parentheses. For example:
// Create a new element <div> and write it to the variable
let newElement = document.createElement ('div');
The new element will be accessible from the script, but it will not appear in the markup until we tell JavaScript where to place the new element. To do this, you can use append method:
// Find the parent element
let parent = document.querySelector('.parent');
// Add a new element to the page
parent.append(newElement);
Elements that were created using the createElement method can be changed in the same way as any others.
Clearing the input field
To prevent the user from mistakenly submitting the form several times, it is better to clear the input field after it is submitted. To do this, write an empty string to its value property. Like this:
let input = document.querySelector('input');
input.value = '';
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 “Conditions and creating elements” — Conditions and creating elements — HTML Academy</title><meta name="csrf-token" content="33764caf322823086fca37a7326b9bd2a54"><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/conditions-creating-elements/summary"><meta name="theme-color" content="#2f358f"></head><body class="course-interface course-interface--light course-interface--full" data-base="/assets/courses/19/"><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/conditions-creating-elements/finish-comments">Finishing the comment section</a><div class="main-nav__course-item main-nav__course-list main-nav__course-list--collapsed"><b class="main-nav__course-title">Conditions and creating elements</b><span class="main-nav__course-stat">15/16</span><div class="main-nav__course-contents"><a class="main-nav__course-contents-link" href="/courses/javascript-basics/conditions-creating-elements">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/conditions-creating-elements/include-script">1. Include the second script</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/create-counter">2. Creating a like counter</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/change-counter-value">3. Changing the counter value</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/classlist-contains-method">4. The classList.contains method, checking for the existence of the class</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/if-statement">5. The conditional statement if</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/else-statement">6. The else statement, alternative branches</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/change-value-from-markup">7. Change the value from the markup</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/news-comments">8. Comments for the news site</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/append-method">9. The append method, adding content</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/create-element-method">10. The CreateElement method and creating an element</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/add-element-to-page">11. Adding an element to the page</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/submit-form">12. Add a comment when submitting the form</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/change-element-properties">13. Changing the properties of the created element</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/finish-comments">14. Finishing the comment section</a></li><li class="main-nav__course-contents-item main-nav__course-contents-item--current"><a href="/courses/javascript-basics/conditions-creating-elements/summary">15. Summary of “Conditions and creating elements”</a></li><li class="main-nav__course-contents-item"><a href="/courses/javascript-basics/conditions-creating-elements/task-list">16. Test: Task list</a></li></ul></div></div><a class="main-nav__course-item main-nav__course-button main-nav__course-button--next" href="/courses/javascript-basics/conditions-creating-elements/task-list">Test: Task list</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%2Fconditions-creating-elements%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%2Fconditions-creating-elements%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 “Conditions and creating elements”</h1><div class="course-theory__content-text"><h2>How to include several scripts on a page</h2><p>In order to include yet another file with JavaScript code on a page, use the <code>script</code> tag again:</p><pre><code><body>
<script src="themes.js"></script>
<mark><script src="likes.js"></script></mark>
</body></code></pre><p>The browser processes the instructions sequentially: first in the first file, then in the second, as though they were located in a single place. Applications are often divided into several files, where usually one task corresponds to one file: for example, managing themes or subscribing to a newsletter.</p><h2>Numbers</h2><p>A variable can be assigned a value. Numbers do not need to be enclosed in quotation marks:</p><pre><code>let number = <mark>0</mark>;</code></pre><p>To increase or decrease the number in JavaScript, you can use various entries:</p><pre><code>// Fully entry
number = <mark>number + 2</mark>; // Variable value: 2
number = <mark>number - 2</mark>; // Variable value: 0
// Short entry
number <mark>+= 2</mark>; // Variable value: 2
number <mark>-= 2</mark>; // Variable value: 0
// Increase the number by 1
number<mark>++</mark>; // Variable value: 1
// Decrease the number by 1
number<mark>--</mark>; // Variable value: 0</code></pre><h2>classList.contains method</h2><p>The <code class="nowrap">classList.contains</code> method checks if an element has a class:</p><pre><code>element.<mark>classList.contains</mark>('class');</code></pre><p>The method will return <code>true</code> if the element has a class, and <code>false</code> if there is no class. The <code>true</code> and <code>false</code> values are called boolean values. There are only two such values.</p><h2>Conditional statement</h2><p>A conditional statement allows you to perform actions depending on a <i>condition</i>. A condition is an instruction that returns <code>true</code> or <code>false</code>. A conditional statement looks like the following:</p><pre><code><mark>if</mark> (condition) {
// Instructions that are executed if the condition is true
} <mark>else</mark> {
// Instructions that are executed if the condition is false
}</code></pre><h3>if</h3><p>The condition is written in <i>parentheses</i> after the word <code>if</code>. After that, instructions that will be executed if the condition is <i>true</i> are written inside the <i>curly braces</i>. A condition is considered true if the statement inside the parentheses returns <code>true</code>.</p><h3>else</h3><p>The statement <code>else</code> tells JavaScript what to do if the condition is false. Instructions that should be executed if the condition returns <code>false</code> are written inside the curly braces after <code>else</code>.</p><p>The use of conditional statements in a script is also called branching, and the code inside the curly braces is called a branch.</p><h2>append method</h2><pre><code>parent-element.<mark>append</mark>(element to be added);</code></pre><p>The <code>append</code> method adds the element in parentheses to the end of the parent element. However, the contents of the parent element are not overwritten. You can use this method to add elements and strings of text.</p><h2>createElement method</h2><pre><code>document.<mark>createElement</mark>('tag name');</code></pre><p>To create a new element on the page where the script is included, you need to use the word <code>document</code>. Indicate the element to be created inside the quotation marks in parentheses. For example:</p><pre><code>// Create a new element <div> and write it to the variable
let newElement = document.createElement (<mark>'div'</mark>);</code></pre><p>The new element will be accessible from the script, but it will not appear in the markup until we tell JavaScript where to place the new element. To do this, you can use <code>append</code> method:</p><pre><code>// Find the parent element
let parent = document.querySelector('.parent');
// Add a new element to the page
parent.<mark>append(newElement)</mark>;</code></pre><p>Elements that were created using the <code>createElement</code> method can be changed in the same way as any others.</p><h2>Clearing the input field</h2><p>To prevent the user from mistakenly submitting the form several times, it is better to clear the input field after it is submitted. To do this, write an empty string to its <code>value</code> property. Like this:</p><pre><code>let input = document.querySelector('input');
input.value = <mark>''</mark>;</code></pre><br><a class="button button--green button--large button--wide button--icon" href="/courses/javascript-basics/conditions-creating-elements/task-list"><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%2Fconditions-creating-elements%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%2Fconditions-creating-elements%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%2Fconditions-creating-elements%2Fsummary" autocomplete="off" method="post" data-submit="o"><input type="hidden" name="csrf_name" value="csrf69aea4f1572b4"><input type="hidden" name="csrf_value" value="8375507a59d5482dee5bc0bbb0b18b98"><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%2Fconditions-creating-elements%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%2Fconditions-creating-elements%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%2Fconditions-creating-elements%2Fsummary" autocomplete="off" method="post"><input type="hidden" name="csrf_name" value="csrf69aea4f1572b4"><input type="hidden" name="csrf_value" value="8375507a59d5482dee5bc0bbb0b18b98"><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%2Fconditions-creating-elements%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="csrf69aea4f1572b4"><input type="hidden" name="csrf_value" value="8375507a59d5482dee5bc0bbb0b18b98"><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>