1. What is Full Stack development?
Full Stack development involves developing both the front end and back end of the web application/website at the same time. This process includes three layers:
- Presentation layer (frontend part responsible for user experience)
- Business logic layer (backend part refers to the server side of the application)
- Database layer.
2. What do Full Stack Web Developers do?
A Full Stack Web Developer is a person who is familiar with developing both client and server software. In addition to mastering CSS and HTML, they are also know how to program browsers, databases, and servers.
To fully comprehend the role of Full Stack developer, you must understand the web development components – front end and back end
The front end comprises a visible part of the application in which the user interacts, while the back end includes business logic.
3. Name a few Full Stack developer tools.
Some of the popular tools used by full-stack developers to make development more accessible and efficient are:
- Visual Studio Code
4. What skills do you need to be a full-stack developer?
A Full Stack developer should be familiar with:
- Basic languages – Must be proficient in basic languages like HTML, CSS, and SQL.
- Back-end frameworks – Express, Django, NodeJS, Ruby on Rails
- Databases – MySQL, SQLite, Postgres, MongoDB, Cassandra, Apache storm, Sphinx
- Additional skills recommended – Git, Machine Learning, SSH, Linux Command, Data Structures, Character encoding.
5. Explain Pair Programming?
As the name suggests, Pair Programming is where two programmers share a single workstation. Formally, one programmer at the keyboard called the “driver” writes the code. The other programmer is the “navigator” who views each line of the code written, spell check, and proofread it. Also, programmers will swap their roles every few minutes and vice-versa.
6. What is CORS?
Cross-origin resource sharing (CORS) is a process that utilizes additional HTTP headers to tell browsers to provide a web application running at one origin. CORS accesses various web resources on different domains. Web scripts can be integrated using CORS when it requests a resource that has an external origin (protocol. Domain, or port) from its own.
7. What is Inversion of Control (IoC)?
Inversion of Control (IoC) is a broad term used by software developers for defining a pattern that is used for decoupling components and layers in the system. It is mostly used in the context of object-oriented programming. Control of objects or portions of a program is transferred to a framework or container with the help of Inversion of Control. It can be achieved using various mechanisms such as service locator pattern, strategy design pattern, factory pattern, and dependency injection.
8. What is Dependency Injection?
Dependency Injection is a design pattern by which IoC is executed. Injecting objects or connecting objects with other objects is done by container instead of by the object themselves. It involves three types of classes.
- Client class: It depends on the service class.
- Service class: It provides service to the client class.
- Injector class: It injects service class objects into the client class.
9. What is Continuous Integration?
Continuous Integration (CI) is a practice where developers integrate code into a shared repository regularly to detect problems early. CI process involves automatic tools that state new code’s correctness before integration. Automated builds and tests verify every check-in.
10. What is multithreading and how it is used?
The main purpose of multithreading is to provide multiple threads of execution concurrently for maximum utilization of the CPU. It allows multiple threads to exist within the context of a process such that they execute individually but share their process resources.
11. How is GraphQL different from REST?
This is typically a difficult question to answer, but a good developer will be able to go through this with ease. The core difference is GraphQL doesn’t deal with dedicated resources. The description of a particular resource is not coupled to the way you retrieve it. Everything referred to as a graph is connected and can be queried to application needs.
12. List the ways to improve your website load time and performance.
There are quite a lot of possible ways to optimize your website for the best performance:
- Minimize HTTP requests.
- Utilize CDNs and remove unused files/scripts.
- Optimize files and compress images.
- Browser caching.
- Apply CSS3 and HTML5.
- Optimize caches.
13. What is the Observer pattern?
The purpose of the Observer pattern is to define a one-to-many dependency between objects, as when an object changes the state, then all its dependents are notified and updated automatically. The object that watches on the state of another object is called the observer, and the object that is being watched is called the subject.
14. What’s the difference between a Full Stack Engineer and a Full Stack Developer?
A Full-Stack engineer is someone with a senior-level role with the experience of a Full-Stack developer, but with project management experience in system administration (configuring and managing computer networks and systems).
15. What is polling?
Polling is a method by which a client asks the server for new data frequently. Polling can be done in two ways: Long polling and Short Polling.
- Long polling is a development pattern that surpasses data from server to client with no delay.
- Short polling calls at fixed delays and is based AJAX-based.
16. What’s the difference between GET and POST?
The following table compares the GET and POST:
|GET is used to request data from a specified resource.
|POST is used to send data to a server to create/update a resource.
|Can be bookmarked
|Cannot be bookmarked
|Can be cached
|Parameters remain in the browser history
|Parameters are not saved in the browser history
|Data is visible to everyone in the URL
|Data is not displayed in the URL
|Only ASCII characters allowed
|Binary data is also allowed
17. How can you prevent a bot from scraping a publicly accessible API?
If the data within the API is publicly accessible, then it’s not possible to prevent data scraping completely. However, there is an effective solution that will deter most people/bots: rate-limiting (throttling).
Throttling will prevent a specific device from making a defined number of requests within a defined time. Upon exceeding the specified number of requests, 429 Too Many Attempts HTTP error should be thrown.
Other possible solutions to prevent a bot from scrapping are:
- Blocking requests based on the user agent string
- Generating temporary “session” access tokens for visitors at the front end
18. What is RESTful API?
REST stands for representational state transfer. A RESTful API (also known as REST API) is an architectural style for an application programming interface (API or web API) that uses HTTP requests to obtain and manage information. That data can be used to POST, GET, DELETE, and OUT data types, which refers to reading, deleting, creating, and operations concerning services.
20. What do you mean by data attributes?
Data attribute consists of two parts:
- Must contain at least one character long after the prefix “data-” and should not contain uppercase letters.
- An attribute can be a string value.