Web Browser#
What Is The Web Browser?#
- A web browser (also referred to as an Internet browser or simply a browser) is application software for accessing the World Wide Web or a local website. When a user requests a web page from a particular website, the web browser retrieves the necessary content from a web server and then displays the page on the user's device. More information
- A Web browser is a client program that uses HTTP (Hypertext Transfer Protocol) to make requests of Web servers throughout the Internet on behalf of the browser user. Most browsers support e-mail and the File Transfer Protocol (FTP), but a Web browser is not required for those Internet protocols, more specialized client programs are more popular. More information
How Does It Work?#
- So, when you enter an URL in your browser, the browser will find the IP address for the domain using the DNS.
- Once the browser has identified which server is going to serve, it will initiate a TCP connection with the server and begin the HTTP exchange. An HTTP exchange involves the client (the browser) which sends a request, and the server replies back with a response. Usually, our browser will be supported to received many kind of formats in the server's response such as HTML, JSON, XML, image etc.
- Assume the browser will receive a HTML file, then the browser will parse the HTML and fetch other additional resources from server such as images, CSS documents or JavaScript documents which are included in the HTML content.
- The browser renders and displays the HTML content which is the web page.
Web Browser Components#
- Any web browser has two elements- front-end and back-end. The front-end is the interface we interact with, which looks fairly simple. However, it’s the complex back-end that facilitates the core functioning of a browser. A browser has the following main components.
User Interface#
- The interface is the space where users interact with the browser. It includes the address bar, on-screen controls like home, back, forward, and refresh, followed by the part where the web page is displayed, bookmarks button, and all other options on the browser screen.
Browser Engine#
- The Browser Engine provides a link between the user interface and the rendering engine. It manages and manipulates the rendering engine based on inputs from various user interfaces.
Rendering Engine#
- The Rendering Engine renders the requested web page on the browser screen. A web page is a document commonly written in HTML- rendering engine converts this document and data to an understandable format so that users can see the desired site, image, or video.
- It deals with HTML and XML documents and other files to generate the layout displayed in the user interface. The rendering engine can also work with other types of data with the help of certain plugins and extensions. Below are the rendering engines used by major web browsers:
- Blink – Google Chrome, Opera, Microsoft Edge (previously used EdgeHTML).
- WebKit – Used in Safari.
- Gecko – Mozilla Firefox.
- Trident – Internet Explorer.
- Presto – Legacy rendering engine for Opera.
Networking#
- The Networking component handles internet communication and security. It retrieves the URLs using common internet protocols like HTML and FTP.
JavaScript Interpreter#
- The JavaScript Interpreter, as the name suggests, interprets and executes the JavaScript code embedded in a website. The results then are sent to the rendering engine for display.
UI Backend#
- UI Backend helps to draw basic widgets like a select box, an input box, a window, a check box, etc. It uses the underlying operating system user interface methods for the same.
Data Storage#
- It is a uniform layer that the browser uses to store all its data including Cookie, Local Storage, Session Storage, IndexedDB, WebSQL, and FileSystem.