Course overview
4 modules of 3 sprints delivered over 12-16 weeks
Objective
The objective of this course is to give people with no prior software development experience an introduction to programming and thinking about data. Common next-steps after this course are to get an entry level job in tech or IT, or to continue learning more advanced software engineering techniques to prepare for a software engineering job.
Primarily this is achieved by teaching programming concepts with JavaScript and Python and data concepts with SQL in spreadsheets. We also focus on professional development skills such as communicating effectively and working well on a team.
A pre-requisite of this course is having completed Code Your Future’s Intro to Digital course which teaches the basics of HTML and CSS.
Modules
Welcome to Code Your Future
- Create a work folder
- Check Git Installation
- Version control software
- Sharing history
Onboarding
- Inspecting a commit
- Inspecting previous versions
- Forking a repository
- Working locally
- Viewing files from a git clone
- Branching
- Merging
- Form building
- Install a UNIX based operating system
- Install Node with nvm
- Interacting with computers
- Using an interface
- Terminal interface
- Prep dir
- Running scripts
- Logging
- Classifying data
- Saving expressions
- Declarations and statements
- Comparing current and target output
- Conditionally executing code
- Errors
- Interpreting errors
- Interpreting this error
- Reusing variable names
- Interview Introductions
- Functions
- Percentages
- Declaring functions
- Playing computer
- Scope
- Returning from a function
- Reusing the function
- Parameterising a function
- Solving Problems with Functions
- Throwing Errors
- Pseudocode
- Breaking Down a Problem
- Undoing a Commit
- Ignoring Files
Structuring and testing data
- Evaluating expressions
- Comparing current and target output
- Writing an assertion
- Forming sub-goals
- Accessing strings
- Refactoring repetition
- Identifying missing tests
- Testing frameworks
- Starting a project
- Using packages
- Installing Jest
- Jest's Application Programming Interface
- First test case
- Interpreting feedback
- Dead Code
- Generalising further
- Anonymous functions
- Arrow functions
- Testing Workshop
Data groups
- Prep dir
- Creating test files
- Grouping data
- Arrays
- Iteration
- References
- Mutation
- Side effects
- Arrays Workshop
- Fail Fast Prep
- Ordered data
- Key-value pairs
- Accessing properties
- Query strings
- Parsing a single key-value pair
- Access with variables
- Parsing multiple parameters
- Objects Workshop
- Prep Conflict Resolution
- User interfaces
- Implementing a character limit
- The DOM
- Querying the DOM
- Updating the interface
- Timers
- DOM events
- Reacting to events
- Refactor
Data flows
- How the internet works
- Usability Workshop Pre-reading
- Rendering Data as UI
- Composing elements
- Creating elements with functions
- Creating elements with <template>
- Reusable components
- Using map
- Gathering requirements
- Reacting to user input
- Identifying state
- Refactoring to state+render
- Introducing new state
- Rendering based on state
- Capturing the user event
- Re-rendering
- Actually re-rendering
- Fetching data
- Latency
- Synchronous execution
- Callbacks
- Requesting from a server side API
- Promises
- .then()
- async/await
- Fetch Films