embedding in html
JavaScript is embedded in HTML in <script>
tags.
variables
let someVariable = "someString"
const someConstant = 3
arrays
JavaScript arrays are zero-indexed:
let array1 = [1, 2, 3, 4];
let array2 = [100, true, "JavaScript"];
array1[0] // returns 1
array1.push(5);
strings
Strings are C-style.
template strings
day: ${day}, index: ${index};
operators
===
flow control
C-style:
if
while
for
foreach
forEach
works by defining an anonymous function that takes action on each element in the array:
array1.forEach(function(day, index) {
…
});
// or, with a lambda:
someArray.forEach(item => {
…
});
type conversions
Parse a string to integer: parseInt
functions
function function-name(arg1, …) {
…
}
object literals
let person = {
firstName: "John",
lastName: "Doe",
greet: function() {
console.log("My name is " + this.firstName);
}
};
selecting html elements
// By ID:
document.getElementById("some-value");
// By class:
document.querySelector(".class-name");returns the first matching element
document.querySelectorAll(".class-name"); returns a NodeList of all matching elements
// By tag:
document.querySelector("tag-name[attribute-name='attribute-value']");
document.querySelector("#someId someAttribute");
Getting / Setting / Removing Attributes
let links = document.querySelectorAll(".classname");
links.forEach(function(link) {
link.setAttribute("target", "_blank"); // set the "target" attribute to "_blank"
});
Accessing an Element’s class
“class” is a reserved word in JavaScript, so instead of…
link.class
…use:
link.classList
window object
The window object hosts the DOM for the current tab.
adding an event listener to window
Creates an event listener that listens for the DOMContentLoaded event and runs the lambda specified in the segment argument when the event occurs:
window.addEventListener('DOMContentLoaded', () => {
…
}
events for input boxes
'change'
when the value in an input box changes'keyup'
when a key is pressed and released