The audience for this project is people that are interested in web development (or software development in general), have no-to-little academic or professional experience and are looking for a way to get started.
There are of course approximately a billion resources for this kind of information on the web but primarily because there are so many sources of information, it is often overwhelming to determine what is the "best" or "right" way to get going. I'm a software developer myself with twenty years experience developing with numerous technologies and languages and this is my way of presenting "how to get started". It is intended for my family, friends and acquantances that have expressed any interest in learning how to be a software developer so that they can avoid the problem of feeling overwhelmed and hence never getting started and finding out if software dev is a good fit for them.
There are many great ways someone could find out if software dev is a good fit - this is just one way. I believe the approach outlined below is a good approach for a couple of reasons:
-
Often people with no-to-little experience are not sure if they will be able to sustain an interst in software dev - they want to find out. In this situation, starting out on "real dev things" is key - you will get to see what it is really like to do what software developers do with a small investment of your time. This tutorial introduces some keys tools and technologies developers use every day and using them right away is the best way to find out if you are interested in continuing down the path.
-
This approach is straightforward, technically simple and can be done in small pieces to get working the basics of what any dev must know... in general. Depending on what languages or platforms you may end up working with, the details may be different and of course there are thousands of tools and platforms available to do dev work with. But in general, if you find this particular process painful or uninteresting, software dev may not be for you.
With that preamble out of the way, hopefully this helps bootstrap your first dev project... the first of many!
Step 1 to any good dev project is to create a code repo. There are lots of good reasons to use a code repo - here's a link to a generic overview if you're interested in learning more. The basic reason you would want to use a code repo is just to have a safe place to store your code in the cloud that is accessible from any device i.e. you don't have to worry about losing your project and to enable you to easily work with others.
There are lots of tools out you can use for a code repo (aka source control) but one prolific industry standard is Git (wikipedia link). Git is awesome and there's a very nice web application that most people use with it - GitHub. Both Git and GitHub are free... these are powerful tools with lots to learn but they are also very easy to use for the basics so don't get lost in the details. The goal for now is just to setup one code repo. Here are the steps:
- Install Git on your local machine. Instructions for most OS can be found here
- Create an account on GitHub
- Create a directory on your local machine where you want to keep your code
- (Optional) Setup security... basically, the goal is to connect your local machine to your GitHub account. There are two ways you can authenticate with GitHub - username and password or SSH key. SSH key is the most convenient over time but is likely the more difficult only because most people aren't familiar with using SSH keys :) Here are the instructions on how to do this or you can just skip this and use your username and password initially to get started. You can always setup an SSH key later if you find yourself getting tired of entering username/pw.
- This particular repo (that this README is a part... that you're reading right now) contains a "starter project". Clone this repo from GitHub into that local directory that you created in step 3. Here's how to clone:
- From a terminal (a.k.a. command line) on your computer, in the project directory you created, using Git...
- it looks like this if you want to auth with username/pw:
git clone https://github.com/junosw/web-dev-get-started-basics.git
- If using SSH, this is the command:
git clone [email protected]:junosw/web-dev-get-started-basics.git
Just FYI, "junosw" is my GitHub username.
- it looks like this if you want to auth with username/pw:
- From a terminal (a.k.a. command line) on your computer, in the project directory you created, using Git...
If successful, at this point you have a local dev directory with code that you've sync'd from a code repo in GitHub! This is real developer stuff :) ...most every developer in the real world starts a project this way, whether a personal project or when joining a new company. So let's go to Step 2 - do something with a real project.
First thing you need is a code editor... think, "Microsoft Word" but for code. There are tons of editors out there, many are free. A fairly popular one that I use is VSCode (it is free). Download that one or explore others and find one you want to try out.
- Get code editor
- In the editor, open the code directory you created earlier. In VSCode this is just a matter of "Open folder" then browse to the directory you created, where the code is.
- At this point you should be looking at this starter project
- A couple notes on the project files/folders:
- "src" is very common shorthand for "the directory where the source code is at"
- This is a very basic web page and a basic folder structure. Any project is free to organize the code however they like but typically people use expected conventions so that other developers can find things easily.
- My use of "index" for file names is just a generic convention for "the starting point file". Typically a web project would have many files with specific, meaningful names.
- The "templates", "styles" and "scripts" are the three building blocks of pretty much every web site.
- JQuery is a library that provides a bunch of basic functionality - you can see I'm using it here to change the image on button click (in
src/scripts/index.js
)
- Run the app! - this is an important step in any dev project - get the thing running locally. For this project, this is drop-dead simple - just open
src/templates/index.html
in your browser and you'll see the web page I've made. - Modify the code - using your code editor, open that same file and feel free to modify the html. You can also modify
styles/index.css
orscripts/index.js
to change the css style or javascript respectively. Each of these three technologies, HTML, CSS and Javascript are deep topics in and of themselves but you can see in this project that I've done something very basic and you can Google each thing I've added to learn more.- Once you've changed something, just refresh the page in the browser to see the change
- A very basic change to test this would be to just change "Web Dev Getting Started" to say something else
Learn more! ...or not :)
If you've followed all the steps, gotten this far and are excited about what you're doing, good news - you might have the soul of a software developer! You should choose the most interesting thing you have encountered and start learning more about it. If that feels overwhelming, choose from the list below!
If you're not excited and this whole process was boring or cumbersome, you could try some of things I've listed just below but ultimately software dev may not be for you... but try anyway - you may get excited still cuz it is real awesome ;)
- Add a new button (e.g. "Click me 2") that changes another set of images next to the current one.
- Take the two button-image sets and put borders around them and make them look nice on desktop and mobile.
- (Design oriented) Make the whole page prettier.
- (Tech oriented) Write an AJAX call to pull content from https://www.google.com and display it in this page.
- (Next level...) Make a server using Node JS and write an AJAX call from
index.html
to your server!
From here, find good learning resources and just play around or figure out a real thing you want to build then find specific tools/packages/etc to build what you want. I'm happy to help with either of those or some other way you might want to go :)
Good luck and let me know if you have any questions or trouble getting something working!