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
Onboarding
- GitHub.dev
- Install VSCode
- Check Git installation
- Create a work folder
- Version control software
- Sharing history
- Inspecting a commit
- Inspecting previous versions
- Forking a repository
- Working locally
- Viewing files from a git clone
- Branching
- Form building
- Databases with Google Sheets
- Accessibility audit
- Interview Introductions
Structuring and testing data
- Interacting with computers
- Using an interface
- Terminal interface
- Classifying data
- Evaluating expressions
- Prep dir
- Saving expressions
- Declarations and statements
- Functions
- Running scripts
- Logging
- Errors
- Percentages
- Declaring functions
- Playing computer
- Scope
- Returning from a function
- Reusing the function
- Parameterising a function
- Solving Problems with Functions
- Comparing current and target output
- Writing an assertion
- Interpreting errors
- Interpreting this error
- Reusing variable names
- Conditionally executing code
- 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
- 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
- Ordered data
- Key-value pairs
- Accessing properties
- Query strings
- Parsing a single key-value pair
- Access with variables
- Parsing multiple parameters
- Objects Workshop
- 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
- 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