Project Icon

curriculum

Techtonica开源课程 助力软件工程职业发展

Techtonica开源课程是一个全面的软件工程培训项目,涵盖Web开发全栈技能。课程内容包括HTML、CSS、JavaScript、React、数据库和API等技术,同时融入职业发展和团队协作培训。通过实践项目和工作场景模拟,帮助学员掌握技能并顺利进入科技行业。课程针对失业或就业不足人群,提供基于需求的补贴学费和奖学金支持。

Welcome to the Techtonica curriculum!

Techtonica is a non-profit project of SocialGood that offers a software engineering training with a need-based, sliding-scale, subsidized tuition and stipend scholarships for intensive tech training and job placement for unemployed or underemployed folks. For more information, please see our website: Techtonica.org

Program participants will learn to do full-stack web development using JavaScript. What bootcamps and Techtonica have in common is the fact that they are intensive training. However, bootcamps can be pretty passive classroom learning and they cost $15,000+ for the students.

Techtonica aims to be more like the workplace to make the transition into the industry better—instead of having an instructor constantly guiding you (which you won't have in any software engineering job), you are given a general schedule of topics and assignments (see our curriculum repo for an idea of the resources provided) and you're expected to figure out what to do on your own or in collaboration with volunteers, mentors, tech groups, and other participants. We’re making Techtonica’s program as hands-on and project-based as possible to best prepare you for work in tech.

Jump to Curriculum Table of Contents.

Volunteering:

If you would like to contribute to the curriculum, please sign up here, then choose an issue in the to-do list.

Get started:

  • Choose an issue from the TO-DO column that seems right for you & leave a comment for Techtonica staff. If you know someone connected to Techtonica, they may be able to add you to our slack channel. If you are here for GHC or Hacktoberfest, message Cristina, Ruthie or Sarah and say you'd like to pick up the issue.
  • In the issue, you should find a link for a lesson outline and for our resources about the topic.
  • If it is in the "TO-DO" column, that means it is available, even if there's an "assignee".
  • To create an outline, fork the repo or commit directly onto the main branch. Here is a topic outline template that explains what we need for each section.
  • To edit a slideshow, you'll need to request edit permission by clicking View Only > Request Edit Access, or message Alina. If you are logged into an account ending in @gmail.com, you can simply make a copy, edit, and transfer ownership to techtonicaorg@gmail.com when you finish. Either way, save on top of the sample template used in the slide, and cut any slides you find unnecessary.
  • To make a video, one effective solution has been to record your screen as you explain the lesson slides to the learner. An alternative can be a video found online that covers all the objectives of the lesson in a way suited to beginners.
  • Here is an example of a great lesson trio: MongoDB Slides, MongoDB Lesson Outline, MongoDB Video.

While working:

  • Comment in the issue if you have a question, or send a slack message.
  • People are welcome to team up on an issue. If you see someone is already assigned but you want to help, leave the other assignee a message on the issue about collaborating.
  • Please note the due date! Any amount of help is appreciated, but if the deadline approaches and you won't be able to complete it, please leave a comment about your progress and unassign yourself from the issue so someone else can pick it up. If you forked the repo, go ahead and make a pull request with what you have, and transfer ownership of a copied slideshow to techtonicaorg@gmail.com.

Completed curriculum:

  • Place a "completed" label on the issue once you've completed it, make a pull request to Techtonica/curriculum main, and leave comments about your work if you like. Grazie Mille!!

We'd love your help in improving this curriculum. See CONTRIBUTING for details.

Table of Contents

The following is the approximate sequence of the topics during the program but is always being tuned and optimized so if you have questions, please open an issue.

Week 0 - Pre-Work

Before beginning the program, participants meet weekly for 4 weeks to learn JavaScript fundamentals. Participants should memorize common JavaScript built-in functions within the first month.

Week 1 - Onboarding & Developer Tools

  1. Welcome, Tips, and Rules
  2. Expectations While at Techtonica
  3. How to Learn
  4. Professionalism
  5. Roles in Tech
  6. Intro to Command Line Interface Tools
  7. Advanced Command Line
  8. Bash Profile
  9. Vim
  10. Homebrew 📝
  11. How to Pair Program
  12. Project 0 - Week 1 Review
  13. Operating Systems
  14. Keyboard Shortcuts
  15. Ergonomics
  16. Growth Mindset
  17. Asking Good Questions
  18. Networking (Career)
  19. Chrome Developer Tools: Setup
  20. One of either: Living in Open Workspaces or Working Remotely depending on program status. 😷
  21. HTML
  22. Intro to CSS
  23. JS HTML DOM Methods
  24. Debugging
  25. Recipe Page Project: HTML

Week 2 - Webpages: HTML & CSS

  1. Git Version Control
  2. .gitignore
  3. Using GitHub for Code Storage
  4. GitHub Collaboration
  5. Operating Systems
  6. Local Development with VS Code
  7. Article: What Exactly is the DOM?
  8. How the Internet Works (The Other Kind of Networking)
  9. Intro to DNS
  10. Recipe Page Project: CSS
  11. Media Queries
  12. UI/UX
  13. Bootstrap
  14. Building Confidence
  15. Recipe Page Project: Bootstrap
  16. Solving Code Challenges
  17. Git Part 2: Study Guide
  18. Portfolio Project: HTML, CSS & Bootstrap
  19. Using GitHub for Project Collaboration
  20. Portfolio Project: Personal Branding
  21. Reading/Writing Documentation
  22. Writing Readable Code
  23. Deploy your Portfolio Project: Deploying Client-Side Apps with Netlify
  24. Portfolio Project: Collaboration and Review

Week 3 - JavaScript Fundamentals

  1. JavaScript 1 - Variables, Strings, Numbers
  2. JavaScript 2 - Arrays, Functions
  3. JavaScript 3 - Conditionals, Comparisons, Booleans
  4. JavaScript 4 - Loops
  5. JavaScript 5 - Switch Statements
  6. JavaScript 6 - Object Literals
  7. Datetime
  8. Basic JavaScript Practice
  9. Testing & TDD
  10. Assigned Reading - Eloquent JavaScript

Week 4 - Intermediate JavaScript and React

  1. JavaScript DOM Manipulation - formerly jQuery
  2. HTML/JS Game Project
  3. a11y: Accessibility
  4. SEO
  5. Portfolio Project: Incorporate SEO & a11y
  6. JavaScript 7 - Object-Oriented Programming
  7. Mini Project: Object Oriented Programming in JS
  8. Functional Programming
  9. All React Lessons

Week 5 - Web APIs

  1. Node
  2. JavaScript 8 - Regular Expressions / RegEx
  3. Runtime Complexity
  4. Intro to HTTP
  5. APIs & JSON
  6. HTTP Requests Practice
  7. Express
  8. REST APIs

Week 6 - Databases

  1. JavaScript 9 - Async, Callbacks, Promises
  2. Intro to JSON (DigitalOcean)
  3. AJAX
  4. .env & config files
  5. TwilioQuest Exercise
  6. import & require
  7. Install Postgres
  8. Intro to Databases
  9. Data Modeling 1 (Single tables)
  10. SQL 1 (Single tables)
  11. Data Modeling 2 (Multiple tables)
  12. SQL 2 (Multiple tables)
  13. Intro to Docker
  14. Install and Run PostgreSQL using Docker

Week 7 - Advanced JS and React

  1. Full-Stack Web App Using React and Express
  2. Recursion
  3. JavaScript Set object

Week 8 - Testing

  1. Adding Tests to your NodeJS project
  2. Testing with Jest
  3. Rithm School- Testing with Jest
  4. API testing with Jest
  5. Testing React Components with Jest and React Testing Library

Week 9 - Eventonica

  1. Eventonica Project

Week 10 - Full Stack Practice

  1. Deploying to Heroku with React and Node
  2. Optimizing your React/NodeJS Project
  3. Enzyme Testing

Week 11 - Data Structures & Algorithms

Data Structures

  1. Intro to Data Structures
  2. Sprint Plan for Data Structures & Algorithms Week
  3. Data Structures: Stacks
  4. Data Structures: Queues
  5. Data Structures: Linked Lists
  6. Data Structures: Hash Tables
  7. JavaScript Map
  8. Data Structures: Trees

Algorithms

  1. Intro to Algorithms
  2. Algorithms: Searching
  3. Algorithms: Sorting

Week 12 - Final Assessments

  1. Navigating New Codebases
  2. Open-source Projects

Week 13 - Career Week!

  1. Technical Interviewing
  2. Take-home Problems
  3. Non-Tech Interviews
  4. Article by Techtonica Alum: Working in the field as a New Software Engineer out of Bootcamp
  5. Career Week: Machine Learning Engineer
  6. Career Week: Entrepreneurship
  7. Career Week: Data Science
  8. [Career Week:
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号