Skip to content

Shubhamjain287/js-roadmap

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 

Repository files navigation

JS Roadmap

Git Module

  • Version Control System - Benefits & types
  • Git - Introduction
  • Configuration - Git config
  • Repository
  • Commit
  • Stages of a file - Untracked, Staged, Tracked & Modified/Dirty
  • .gitignore
  • Diffing
  • Branching
  • Log command
  • Reset and Revert
  • Cherry Pick
  • Merge conflicts
  • Stashing
  • Remote
  • Pull & Push
  • GitHub & GitLab
  • Merge Request
  • Pull Request
  • Forking

Task:

  1. Set your user name (user.name) and email address (user.email) using terminal
  2. Create a GitHub repository for the js assignments with the main branch as default branch.
  3. Create a new branch, update ReadMe with description, Add LICENSE file (Apache 2.0) and create a Pull request assigning it to me (https://github.com/adityasharma7/hc-js-assignment)

Reference:

  1. https://git-scm.com/book/en/v2/Getting-Started-First-Time-Git-Setup
  2. https://dev.to/smitterhane/git-pull-vs-git-fetch-66m
  3. https://learngitbranching.js.org/
  4. https://git-scm.com/docs/git-config
  5. https://git-scm.com/docs/git-add
  6. https://github.com/git-guides/git-init
  7. https://www.atlassian.com/git/tutorials/inspecting-a-repository
  8. https://www.atlassian.com/git/tutorials/using-branches
  9. https://www.atlassian.com/git/tutorials/saving-changes/git-stash
  10. https://git-scm.com/docs/git-pull
  11. https://www.atlassian.com/git/tutorials/using-branches/merge-conflicts
  12. https://docs.github.com/en/get-started/quickstart/hello-world
  13. https://docs.github.com/en/get-started/quickstart/fork-a-repo
  14. https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests
  15. https://www.simplilearn.com/tutorials/devops-tutorial/version-control
  16. https://www.javatpoint.com/git-log
  17. https://github.com/git-tips/tips

HTML:

  • Introduction to HTML
  • Elements and Attributes
  • Classes and identifiers
  • Forms & Inputs
  • Semantic HTML

Task:

  • Create a Registration and Login page for an eCommerce website

Reference:

CSS Basic Module: Expected: 3 hours

  • Introduction to CSS
  • CSS Selectors
  • Inline, Internal, and External CSS
  • CSS Properties
  • Viewport

Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Properties_Reference https://developer.mozilla.org/en-US/docs/Web/CSS/object-fit https://uxplanet.org/figma-all-you-need-to-know-156b52b88e54 https://www.seobility.net/en/wiki/Viewport https://flukeout.github.io/

JS Module

JS Module 1:

  • Introduction to JavaScript
  • Variables
  • var, let, and const
  • Data types
  • Primitives
  • Type Conversions
  • Operators
  • typeof operator
  • Comparisons
  • Interaction: alert, prompt, confirm
  • Conditional operators: if, '?'
  • Logical operators
  • Loops & iteration
  • The "switch" statement
  • Functions
  • Function expressions
  • console object and its methods

Task:

  1. Find out about the most popular JavaScript frameworks. (At least 5)
  2. Find out about the most popular open-source JavaScript frameworks. (At least 5)
  3. Provided the following array: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] Filter out odd, even, and prime numbers and print them
  4. Provided the following array: [0, 2, 4, 6, 8, 10, 12, 14, 16] Generate and print another list such that: a. every element being twice of elements in the current list. b. every element being half of the elements in the current list.
  5. Provided the following array: [10, 1, 42, 36, 4, 75, 6, 97, 81, 19, 10] a. Find the sum, min, and max b. Print “List is full of prime no” if every element is prime c. Print “List has a prime no” if there is a prime no in it d. Remove duplicate values from the list () Note: Use loops for above problems
  6. What will be the output for below code:
    console.log(typeof undefined)
    console.log(typeof null)

JS Module 2:

  • Objects and its methods (Object.keys(), values(), entries())
  • Array
  • Array - flat()
  • Map and Set
  • Garbage Collection
  • Explore map(), filter(), reduce(), find(), some() and every() methods
  • Strict keyword
  • Cookies
  • Arrow functions

Task:

  1. Find the difference between Object and Map.
  2. Identify the difference between regular functions and arrow functions
  3. Provided the following array: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] Filter out odd, even, and prime numbers and print them
  4. Provided the following array: [0, 2, 4, 6, 8, 10, 12, 14, 16] Generate and print another list such that: a. every element being twice of elements in the current list. b. every element being half of the elements in the current list.
  5. Provided the following array: [10, 1, 42, 36, 4, 75, 6, 97, 81, 19, 10] a. Find the sum, min, and max b. Print “List is full of prime no” if every element is prime c. Print “List has a prime no” if there is a prime no in it d. Remove duplicate values from the list.

Note: Use map(), filter(), reduce(), some() and every() methods for above problems

e. Remove duplicate values from the list without using loop or any of the above methods (map(), filter(), reduce(), some() and every())

  1. Provided an array of integers, find if there are any duplicates in the array.

Output: true - if any value appears at least twice in the array, false - if every element is distinct.

Example: Array -> [10, 1, 42, 36, 4, 75, 6, 97, 81, 19, 10] Output -> true

Array -> [10, 1, 42, 36, 4, 75, 6, 97, 81, 19] Output -> false

  1. Provided array: [10, [1, 42], 36, [4, 75, [6, 97], 81], 19, 10] a. Flatten array to [10, 1, 42, 36, 4, 75, [6, 97], 81, 19, 10] b. Flatten array to [10, 1, 42, 36, 4, 75, [6, 97], 81, 19, 10] c. Implement logic to flatten such arrays for any level. All the arrays of any depth should be flattened to single depth

Reference:

  1. Array.prototype.flat() - JavaScript | MDN

Module 3: Expected: 8 hours

  • “this” keyword
  • Constructor functions and the "new" operator.
  • Numbers
  • Strings
  • Array and its methods
  • Hoisting
  • Scoping
  • Super keyword
  • Error Handling, “try...catch”
  • throw keyword
  • Modules
  • export/import
  • Dynamic import
  • Nested functions
  • Classes
  • Class basic syntax
  • Class Inheritance
  • Extending built-in classes

Task:

  • Provided following array:

[ {“id”: 1, “name”: “Amit Kumar”, “age”: 25}, {“id”: 2, “name”: “Rahul Dixit”, “age”: 20}, {“id”: 3, “name”: “Ravi Joshi”, “age”: 55}, {“id”: 4, “name”: “Rohit Verma”, “age”: 35}, {“id”: 5, “name”: “Ajay Jain”, “age”: 17}, ]

  • Print id and name of the youngest and oldest person
  • Create another list having id and name of all the person above 18 years
  • Find the average age
  • Create 2 list with names starting with only ‘A’ and ‘R’ respectively

Note: Use map(), filter(), reduce, some() and every() methods for above problems

  • Try the below code and identify which of the below programs are a valid case of hoisting?

Program 1: a = 10; console.log(a); var a;

Program 2: a = 5; console.log(a); let a;

Module 4:

  • JSON and its methods(toJSON)
  • Rest Parameters
  • arguments keyword
  • Spread Syntax
  • Recursion and Stack
  • Variable Scope
  • Regular Expressions Task:
  • Implement code to deep clone an object using JSON methods
  • Implement regular expression for name with letters
  • Implement code for sum using recursion Reference:

Module 5: Expected: 8 hours

  • DOM
  • Searching: getElement*, querySelector*
  • Introduction to Events
  • Introduction to browser events
  • Bubbling and capturing
  • Event delegation
  • Browser default actions
  • Dispatching custom events

Task: -

Module 6: Expected: 8 hours

  • UI Events
  • Mouse events basics
  • Scrolling
  • Forms, controls
  • Form properties and methods
  • Focusing: focus/blur
  • Forms: event and method submit
  • Page: DOMContentLoaded, load, beforeunload, unload
  • Scripts: async, defer

Task: -

  • To change the background color of the second column of a table having “n ” rows on click by using querySelector.

Module 7: Expected: 8 hours

  • Resource loading: onload and onerror
  • Popups and window methods
  • Binary data, files
  • LocalStorage, sessionStorage
  • Static properties and methods
  • Private and protected properties and methods
  • Class checking: "instanceof"

Task: -

  • To create a textarea and if a user makes changes to it without saving then show an alert that data is not saved. (Similar to https://stackoverflow.com/questions/ask)
  • Change the color of the cell to red when the user clicks on a cell and revert when the user again clicks.

Module 8: Expected: 8 hours

  • Blob
  • File and FileReader
  • REST API
  • GraphQL
  • XMLHttpRequest and AJAX
  • Fetch API
  • Fetch methods
  • Preflight Request
  • FormData
  • URL objects

Task: -

  • Change image on runtime when it is not available on the specified path while loading the page.

Module 9: Expected: 8 hours

  • Date and time
  • Object to primitive conversion
  • Scheduling: setTimeout and setInterval
  • Callbacks
  • Promise
  • Promises chaining
  • Error handling with promises
  • Promise API
  • Promisification
  • Async/await
  • The "new Function" syntax Task: -
  • Implement a simple code to use a Promise
  • Implement code to handle multiple promises. You have to fetch information of 5 different products from API

Module 10: Expected: 8 hours

  • Function binding
  • Custom errors, extending Error
  • Async iterators and generators
  • Destructuring assignment
  • ECMAScript 5(EC5)
  • ECMAScript 6(EC6)

Module 11: Expected: 8 hours

  • WebSocket
  • SPA(Single Page Applications)
  • SEO(Search Engine Optimization) and how it works with SPA?
  • SSR(Server Side Rendering)
  • CORS (Cross-Origin Resource Sharing)
  • JavaScript & Typescript Best Practices

Task:

  • Verify your code comply with the best practices and fix them if required.

Reference:

CSS Advanced Expected: 8 hours

  • Object fit property
  • Media Queries
  • Box Model
  • Specificity
  • CSS Grid
  • Flexbox
  • Comments
  • Responsive design
  • Material Design
  • Figma
  • NPM and Yarn Task:
  • You are writing a responsive layout for a website that has dramatically different layouts for mobile and desktop. Which of the following media queries would you use and why?

@media (max-width: … @media (min-width: …

Cite 3 sources that back up your position. You cannot cite Stackoverflow. Provide links for all sources and time codes for videos.

Vue.js Training

Module 1: Expected: 8 hours

  • Vue.js : Introduction
  • The Vue Instance
  • Data and Methods
  • Instance Lifecycle Hooks
  • Life cycle diagram
  • Template Syntax
  • Computed Property and Watchers

Task:

  • Create a basic “Hello World!” Vue application.

Module 2: Expected: 8 hours

  • Declarative Rendering
  • Conditionals and Loops
  • Class and Style Bindings
  • List Rendering
  • Event Handling
  • Form Input Bindings
  • Component Basics Task:
  • Create a new branch from last task and Implement a Login and Registration page

Module 3: Expected: 8 hours

  • Transitions
  • Props
  • Filters
  • Directives
  • Custom Directives
  • Mixins
  • Slots

Module 4: Expected: 8 hours

  • Routing
  • Routing Guards
  • Working with API
  • Axios

Task: -

  • Create a ecommerce-clone branch and push files & folders generated for new fresh app using Vue CLI
  • Create a new branch from the last task branch and Implement e-commerce web application (Clone any popular website like Amazon, Flipkart etc or any template of your choice) with a home page and top navigation with dead links.
  • Create a new branch from the last task branch and add a category page which lists all products belonging to the category. Create a new PR with the last task branch as the target branch.
  • You could use Fakestoreapi (https://fakestoreapi.com/) or any other public APIs (https://github.com/public-apis/public-apis)

Module 5: Expected: 8 hours

  • Event Bus
  • State Management
  • Vuex
  • Composition API Task: -
  • Create a new branch from the last task branch. Add features to sort and filter out products based upon price, color or any other field on the category page. Create a new PR with the last task branch as the target branch. Create a new branch from the last task branch. Implement product details page. Create a new PR with the last task branch as the target branch.

Module 6: Expected: 8 hours

Task: -

  • Implement Registration and Login page.
  • Store the token in local storage
  • Implement a interceptor which adds token to headers
  • Use Axios cache plugin to cache product API
  • Update application labels to use internationalization

Module 7: Expected: 8 hours

Module 8:

  • SSR in Vue and prerendering
  • Dynamic content rendering in Vue
  • Vue best practices
  • Modes and Environment Variables
  • Dev Tools ()
  • Postman Task:
  • Verify your code comply with the best practices and fix them if required.

Module Resources:

Ionic Training

  • Ionic Framework - Introduction
  • Hybrid, cross platform and native apps
  • Cordova and Capacitor
  • Webview
  • Components
  • Slots

Task:

Free icons for website

Common JavaScript references:

Top Javascript Frameworks and Libraries to Learn

Frontend

Backend

Website Animations Library

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published