Code for Noobs
17 May 2020
So I've been meaning to write an introductory post about the basics of JavaScript for quite some time. A few weeks ago I managed to finally get something going on this Twitter thread (@not_nabeel)
Let's get into it
0. What is Programming
Programming is our way of telling a computer to do things. This can be anything from checking our spelling to making trippy digital art
The basics of programming are the same in most languages and doesn't involve much math or binary (0010101
) like a lot of people seem to think. Programming languages usually make use of a very small subset of words and concepts of a normal human language like English
The language I'm going to be using is called JavaScript
but many of these concepts are the same in most other programming languages
1. What is JavaScript?
JavaScript is the language used to add interactivity to a website but it can also be used to do pretty much anything you like. JavaScript runs in all modern web browsers and can be accessed through your browser's developer tools, but it can also be used on other devices using something like @nodejs
For our purposes though, we don't need to worry too much about how that all works right now. To get started we'll be using tools like @CodePen, @replit and @glitch which give you text editor and a place to run your code
You'll see some code samples embeded in the
I'll be posting links to the code on these sites as I go along
2. Text Data
In a program, we can store different types of data (known as "data types")
When we store text we use a data type called string
. In JavaScript a string is just text surrounded in either double quotes, single quotes, or `these things`
(which are known as backticks):
"i am text"
"i am also text"
;`me too.`
;`unlike the others,
i can b
multiple lines
lllooonnnggg
and have random spaces`
3. Variables
If we want to keep our data for use at a later stage we need to give it a name, otherwise how do we know what data we're trying to use right? To give a piece of data (or text, in our case) a name we create a variable
We create a variable using let
or const
along with a variable name and the data that we want to give the name to :
View Code
// this code shouldn't do anything if you run it
// we are just creating some variables
let myText = "Hello World"
const myOtherText = "Bye World"
We use let
for data whose data may change and const
for data whose data won't you can remember this like: const = constant
Note that it is also possible to use the keyword
var
to create a variable. This is something that is left over from older versions of JavaScript and can have some effects that are better to just avoid (if you're interested you can read this article about how it impacts variable scope but it is a bit of a more challenging concept to understand)
When creating a variable, there are a few rules we need to follow:
- Variable names must not contain spaces or stuff like
!@#%%^&\*()
, underscores and dollar signs are okay though - Variable names must not be a word the language has set aside for something else. e.g
const
orlet
- Variable names must not start with a number
- Variable names should be descriptive. while names like "x" and "blah" are allowed, if they have no meaning in the context it's better to opt for something people will understand
4. Printing Data
Languages have ways we can show data to a user (or programmer). In JavaScript this is the "console.log" function. We'll discuss functions later on but for now know that when we give them data, and they do stuff
View Code
// print the data
console.log("Bob Smith") //prints -> Bob Smith
// print a variable
const jenny = "Jenny Smith"
console.log(jenny) // prints -> Jenny Smith
5. Numbers
Numbers are another type of data in JavaScript, to store a number we can just write the number. using numbers we can also do things like getting fat or running from the po-lice
-
is plus-
is minus*
is multiply/
is divide
View Code
const myWeight = 100
const food = 100 + 50
const myNewWeight = myWeight + food
console.log(myNewWeight) // print -> 250
const myWeightAfterRunnin = myWeight - myWeight * 0.2
console.log(myWeightAfterRunnin) // print -> 80
But, JavaScript lets us add do maths with anything. so maybe like - don't do this:
View Code
const dontDoThis = "apple" * "pineapple"
console.log(dontDoThis) // print -> NaN (Not a Number)
6. Arrays
Arrays are how we store a set of data. an array can have different data types in it, but usually, we want to be storing the same stuff in an array. we make an array by wrapping our items in [ ]
and separating each item with a comma (,
)
View Code
const myFriends = ["i", "don't", "have", "any"]
const thingsToRemember = ["uhmm", 42, 12, "idk, i guess i forgot"]
const multipleLines = [
"arrays don't have to be",
"on a single",
"line"
]
If we want to get a specific element in an array we can use the variable name with the index (position) of the element. the index starts at 0. we will get undefined
(I'll explain this in a bit) if we try to get a value at an index that does not exist
View Code
const myData = [
"zeroeth index",
"first index",
"second index",
"third index"
]
console.log(myData[0]) // print -> zeroeth index
console.log(myData[1]) // print -> first index
console.log(myData[2]) // print -> second index
console.log(myData[3]) // print -> third index
// indexes that do not exist in our array
console.log(myData[-1]) // print -> undefined
console.log(myData[100]) // print -> undefined
7. Booleans
So far we've looked at strings and numbers, we have an even more basic data type called a boolean. a boolean is a value that can either be true or false. when creating a variable for a boolean we do not wrap the value in quotes
View Code
var myTrueBool = true
var myFalseBool = false
console.log(myTrueBool)
console.log(myFalseBool)
8. Complex Data
If we want to store data that are more complex than the ones we've seen above, we can make use of "objects". use { }
around our data to group more basic data. these use keys
as names for values in the object
View Code
const jenny = {
id: 123,
name: "Jenny",
surname: "Smith",
age: "idk, can't ask a woman that",
favouriteBooks: [
"To not kill a Mockingbird",
"Why are books so voilent, yoh",
],
}
// we can get specific values using their keys
const jennyName = jenny.name
const jennyBooks = jenny.favouriteBooks
9. Undefined and Null
the values undefined
and null
have a special meaning.
undefined
is a representation for a variable that does not have a valuenull
is a value of "nothing"
For example:
- What's wrong with chocolate?
null
- What's a flobuir?
undefined
10. Functions
Functions are a way we can group code for a specific set of instructions, usually with some end purpose. In JavaScript we define a function in one of two ways: using the word function
or with the fat arrow syntax
View Code
// using the "function" keyword
// this creates a variable called "myFunc1"
function myFunc() {
const stuff = "I am Function"
console.log(stuff)
}
// we can also create the variable using
// "let" or "const" like we do for other variables
const myLetFunc = function () {
const stuff = "I am another Function"
console.log(stuff)
}
// fat arrow function
const myFatFunc = () => {
console.log("Phat Funk")
}
// single line fat-arrow functions don't need the {}
const mySingleLineFunct = () => console.log("single line")
To use a function we simply write the name of the function and then add ()
at the end, provided the function doesn't take any data (also known as parameters
)
View Code
const sayHello = function () {
console.log("Hello")
}
// "call" the function
sayHello() // prints -> Hello
const sayBye = () => console.log("BYEE")
// "call" the function
sayBye() // prints -> BYEE
Remember earlier I said that functions take data and do stuff? For us to give a function data we need to tell it what variables to store that data as when we call it. We do this by having the data in the ()
when we create (or 'declare') our function
View Code
function sayHello(name) {
console.log("Hello " + name)
}
// use the function
sayHello("Bob") // print -> Hello Bob
const sayBye = (name) => console.log("Bye " + name)
//use the function
const name = "Jenny"
sayBye(name) // print -> Bye Jenny
When computers are following our code they do so from the top down, so the first line is handled by the computer before the second. the second before the third, etc. functions are a way for us to reuse code that was written on a line higher up in our code. You may notice that we use the variable name
in a lot of different places above. this uses scope
and broadly means any variable name created in a function (or pretty much anywhere between { }
) is only available within that section
Scope complicated, you can read more about it here
Functions can also take multiple parameters, this is done by listing the parameters between the () and separating them by commas. the order that we list them when we create our function is the same as the order we need to put them when using the function
View Code
const sayBye = (firstName, lastName) => {
console.log("Bye " + firstName + " " + lastName)
}
// use the function
const jennyName = "Jenny"
const jennySurname = "Smith"
sayBye(jennyName, jennySurname) // print -> Bye Jenny Smith
Functions are also able to give us back a value after doing some stuff. They do this by using the return
keyword which tells it what to give back. A function stops processing when it sees the keyword return
- anything after it in a function is ignored
View Code
const addNumbers = (num1, num2) => {
const result = num1 + num2
return result
}
const mySum = addNumbers(1, 2)
console.log(mySum) // print -> 3
Summary
That's it for now, I'll definitely be updating this post/series as things are added
Nabeel Valley