Integrating Still.js into Next.js: A Hands-On Guide to Remote Microfrontend Components - Part2

Backer posted 3 min read

In this second part of the Microfrontend series we’re answering another posed question, we explore integrating Still.js with Next.js, focusing on using remote Vendor components. The video includes a real-world use case and a project built from scratch, follow the Design System for implementation

What points will be addressed in the video:

  1. Creation of Next.js project
  2. Generating and embedding Still.js app inside Next.js App
  3. Embedding remote component (straight from npm) into the application
  4. Data exchange between Still.js and Next.js (React)

Remote components

This approach is key in Microfrontends, as it enables embedding components from outside the project structure. It enhances feature sharing, increases decoupling, and reduces the size of the deployable package (e.g. bundle).

The idea behind remote component is for them to be served from somewhere which is not the embedding application itself, as we can see in the bellow architecture:

The above architecture promotes reusability by allowing the same component, available via NPM/GitHub, to be embedded across different applications built with various frameworks. Still.js can play a key role, serving as proxy as needed, by being embedded within these apps as well. Additionally, Still.js enables components to be written in Vanilla JavaScript rather than relying on framework-specific code.

Although NPM and Github are the approaches depicted in the architecture, Still.js adapts well with any other source for embedding remote components.

Self-contained components

This is the optimal situation in which a component can be used remotely, as the idea is that not external dependency exists so to avoid cascade importing, which can be harmful in terms of performance, also might cause JavaScript bloating issues.

Coding snippets specific considerations

Step1:
The Still.js app is integrated into the Next.js project by placing it in a subfolder (we’ll call still-mf/) inside the public/ directory. It is then loaded using the apploader with additional parameters:

useEffect(() => {

    const stillApp = new StillAppLoader();
    stillApp
      .cdn({ env: { STILL_HOME: '/still-mf/', PATH_PREFIX: 'still-mf/' }, version: '1.3.13'})
      .load();

  },[]);

Step2:
Next.js listens to Still.js events via subscription. The Apploader SDK now supports init/on(‘load’) event, improving memory and CPU usage, so no setTimeout needed:

useEffect(() => {
    // …. Above code
    stillApp.on('load', () => {
    
        stillApp.component.ref(ref1).variableName.onChange(newData => {
           console.log(‘Still.js updated the value of variableName to ’, newData);
        });

    });
},[]);

Compared to part one of the series, the main differences in the Still.js app setup for Next.js is the need to specify PATH_PREFIX and, optionally, the framework version to define which Still.js version is used.

Embedding NPM remote component

The video tutorial demonstrates how the StillTreeView vendor component from Still.js is used in a real use case with Next.js + Still.js integration. The component is embedded directly from NPM as a remote as shown in the example below code snippet:

<st-element component="npm/@path/to/package/ComponentName”></st-element>

As conclusion:

While not a bulletproof, Microfrontends are highly effective for complex, enterprise-scale applications. Remote components further enhance this architecture by promoting decoupling, feature sharing, and scalability. Ideally, these components should be self-contained for optimal results. Also, don't forget to check the video for more details.

What’s Next?

  1. Don't forget to check the video
  2. Try implementing a more complex Microfrontend with Still.js including navigation/routing ( routing documentation )
  3. Try to compare different Microfrontend approaches with the way Still.js does disruptively
  4. Share your thoughts and ideas in case you have any concerning to this topic
  5. Bear for the next parts of this series

Se you next time.

If you read this far, tweet to the author to show them you care. Tweet a Thanks
0 votes
0 votes

More Posts

From Vanilla Template to Still.js Components: A Full Build and Deployment Guide

Nakassony Bernardo - Aug 10

Rethinking Microfrontend Architecture combining Still.js with React (or other Framewok) - Arch Serie

Nakassony Bernardo - Jul 13

Still.js - A way to leverage Vanilla JavaScript for Complex and Enterprise Level Web Development

Nakassony Bernardo - Jun 29

Setting Up Next.js Authentication with Supabase: A Complete Guide

Anuj Kumar Sharma - Jan 22

Connect a Solana wallet in Next.js to start building dApps effortlessly.

adewumi israel - Jan 24
chevron_left