Are Web APIs the same as REST APIs? Build More Scalable Web Apps with Web APIs
To answer the question: No, Web APIs are not the same as REST APIs.
Web APIs refer to interfaces that allow applications to interact with the web or devices. This term is broad and can refer to Browser APIs (like WebRTC or Geolocation) or Server APIs (like REST or GraphQL).
On the other hand, REST APIs are a specific type of Server API that adhere to REST principles, focusing on statelessness, resource-based communication, and using HTTP methods like GET, POST, and DELETE.
The Evolution of the Web
Originally, the web was designed as a static site for providing information and connecting individuals to relevant resources, regardless of location. However, it has evolved to become interactive and progressive, with certain aspects also turning decentralized. This article focuses on the web being progressive and more user-friendly.
The Role of Web APIs in Modern Development
Web APIs serve as the backbone of modern web development. With APIs like WebRTC, Web Bluetooth, and Service Workers, developers can create highly interactive, native-like web applications without requiring external plugins. These capabilities make Progressive Web Apps (PWAs) possible, bridging the gap between web and native apps. Check out my extensive article on progressive web apps.
https://michelle-buchi.hashnode.dev/how-to-get-started-with-progressive-web-apps
Some Benefits of Progressive Web Apps
Works on any browser (cross-platform)
Responsive to any device
Functions without network connectivity
Performs like a mobile app
Highly secure
Discoverable via search engines
Boosts app engagement
No installation required
Can be shared through a link
Optionally available on app stores (e.g., Google Play, Apple Store)
Web APIs and Project Fugu
Web APIs here, referring to browser APIs, act as connectors, improvers, and builders for the browser's capabilities. These APIs are inherent to the web and are not third-party APIs purchased from libraries or sites. Instead, they are broadly available and designed to improve the web and enhance products created by developers, reducing boilerplate code and simplifying web interactions.
The significance of web APIs is underscored by the fact that over 70% of activities conducted online occur through the web, highlighting the need for improvements and scalability.
In summary, web APIs are crucial for the success of Progressive Web Apps and the future of web development. They act as enablers of advanced functionalities.
Project Fugu
Project Fugu derives its name from the Japanese word for pufferfish, "fugu." Initially, I was curious about why this project was named after a fish until I learned more about it. The fugu is a dangerous fish that can be delicious when prepared correctly; however, if not handled properly, it can be harmful. This metaphor aptly reflects the project's goal of enhancing the web platform's capabilities to match those of native applications. The correlation here is that the Project Fugu APIs aim to enrich the web (the ‘delicious’ aspect), and if they are not built correctly (the ‘preparation’), they can introduce significant security vulnerabilities. Imagine creating an API accessible to billions without adequate security measures; it would expose individuals to various security risks.
You can find more about Project Fugu and its APIs at https://developer.chrome.com/docs/capabilities/fugu-showcase. Here, you will discover interesting and exciting projects built with web APIs, as well as a comprehensive list of available APIs. Many native app features that were previously unavailable on the web are now accessible, thanks to web APIs.
Why Web APIs?
Web APIs are crucial for several reasons, and their importance should not be overlooked. They empower the browser, transforming the web from a simple content viewer into a powerful application platform. With APIs like WebRTC, WebSockets, Service Workers, Web Bluetooth, and Web XR, you can now accomplish tasks on the web that were once limited to native applications.
Why Should You Start Using Web APIs?
Web APIs offer numerous benefits, including:
Access to Native Device Features: They allow you to access device hardware such as cameras, microphones, sensors, and Bluetooth devices. This means you can make video calls, control robots, and experience augmented reality directly in your browser, without needing to download any apps.
Offline and Background Functionality: Service Workers enable features like push notifications and caching, enhancing the user experience even when offline.
Simplified App Development for Cross-Platforms: Web APIs facilitate easier development across different platforms.
How Web APIs Improve the Web
Web APIs bring the capabilities of native apps to the web, granting access to powerful features without requiring installations or downloads. They also help future-proof the web; as browsers evolve, more APIs will be developed for seamless integration. Additionally, web APIs are accessible across platforms.
Is it Easy to Get Started with Web APIs?
Yes, it is straightforward. Most web APIs are already integrated into browsers, and supported by robust documentation. Since many are native to the browser, there's no need for third-party libraries or installations. This makes getting started seamless, consistent, and accessible across platforms.
Some Web APIs
Web APIs are the cornerstone of the Progressive Web App (PWA) revolution. They form the backbone of improved web functionality and represent the future of web development. Numerous Web APIs are available, and you can find a comprehensive list in the MDN documentation or on web.dev. Below are about 10 Web APIs to help you understand how they work. You can find many more in the MDN docs,web.dev, or via the project fugu documentation.
WebRTC API: Enables real-time audio, video, and data communication directly between browsers without the need for external plugins. It is commonly used for video conferencing and peer-to-peer file sharing.
Web Bluetooth API: Allows websites to communicate with Bluetooth-enabled devices, such as fitness trackers, medical devices, and IoT gadgets.
WebXR API: Provides support for immersive technologies like Virtual Reality (VR) and Augmented Reality (AR), allowing developers to create engaging 3D experiences directly in the browser.
WebSocket API: Facilitates full-duplex communication between the client and server, making it ideal for real-time applications like chat systems, live streaming, and collaborative editing.
Push Notification API: Enables websites to send timely and relevant notifications to users even when the website is not open in the browser, enhancing user engagement.
Web Share API: Provides a standardized way for web apps to share content using native sharing mechanisms, making it easier to share links, files, or text with other applications.
Fetch API: Replaces the older XMLHttpRequest and simplifies asynchronous data fetching.
Web Payment API: Simplifies the online payment process by offering a consistent interface for users to make payments using various methods, such as credit cards or digital wallets.
Geolocation API: Provides access to the geographical location of the user, enabling location-aware functionality like maps, location-based recommendations, or geofencing.
File System Access API: Enables web applications to read from and write to the user’s local file system, creating a native-like experience for file manipulation.
WebRTC Demo
WebRTC enables real-time communication, including audio, video, and data-sharing capabilities. For a simple WebRTC demo, you will need:
index.html
app.js
server.js
WebSocket or HTTP REST API Inbuilt WebRTC API Local and remote video elements Buttons to manage peer connections WebRTC configurations
How It Works
Access User's Camera and Microphone: Create a function to access the user's camera and microphone, displaying the local stream on the local video element.
Peer Connection: Implement a function to handle media exchange.
Signaling: Simulate sending and receiving data through the signaling server.
Remote Stream Handling: Display the remote track in the remote video element. ICE Candidates: Exchange these candidates with peers to establish a connection.
Web APIs are the cornerstone of modern web development, enabling developers to build powerful, scalable, and engaging applications. Whether you're exploring WebRTC for real-time communication or leveraging the File System Access API for native-like experiences, the possibilities are vast. Start experimenting today and contribute to the web's progression.