Monday, December 2, 2024

React - Makeover in React: W3Schools How To


When it comes to building a React app, I get used to searching for a UI library to build the front pages, a straightforward way to achieve fashionable and user-friendly look and feel. One day, I was looking for technical help on the Internet and came across W3Schools How To site. It surprised me because it shows a way to create fantastic web components using the common plain technologies, easy, fundamental, transparent. So, I started trying some of them in React and shared some in this blog.

The project is available on GitHub. You can clone and run it locally with the following commands.

git clone https://github.com/plus-tech/reacthowto.git

(move to the newly created folder, reacthowto)

npm install

npm start



A Typical Example - Slideshow Carousel


We start with Slideshow Carousel, which presents an image gallery to users.


Slideshow/Carousel Example

The idea is to load all the images but make only one visible at one time and hide all the others. 

To make an image visible, set its “display” attribute to “block”.  

To make it invisible, set “display” attribute to “none”.  

(Note: This can be done by using conditional rendering as well, shown in Manipulate the DOM section.)

Clicking Prev button will hide the current image and display the one before it. Next button will do the similar thing but show the next image. 

We will use a state variable to control which image is available.

Let us walk through this step by step.

Load images - Load all the images on a given folder into a list and get the number of them at the same time.



Define a state variableIt indicates which image is currently active, the default is set to 0, the first one in the list.



Function to change images’ visibility - If you click the Next button, the next image is set active, but if the currently active one is the last in the list, then loops back to the first. On the contrary, the previous image is set active if you click the Prev button.



Show images - Here we use a <div> element to hold the <img> element and use map function to generate the list of <div>s. As you can see, the display attribute in style of each element is set to either “block” or “none”.



Button’s onClick - When you click on either Prev or Next button, ShowCurrImg function is called to shift the active image.



Dots on the bottom - A dot is associated to an image in the same order. You click on a dot, and as a result, the underlying image is brought to the front.



The source files are available on GitHub. 

  • slidecarousel.css
  • slidecarousel.jsx



List Grid View


Let us explore one more example, looking at using a function to generate elements instead of setting their style. 

In this example, when you click on the List button, the button is highlighted, and the column cards are arranged as a vertical list. The Grid button arranges the cards as a 2x2 grid. 


List View

Grid View

When the items are in List view, the List button becomes active, and vice versa. The showBtn function returns the buttons according to the current state of view.



How to embed the buttons into another <div>? Simply put the function into a pair of curly brackets, shown below.



For more details, please refer to the below files.

  • listgridview.css
  • listgridview.jsx


Add an Event Listener


When I tried to build the floating bar component, I needed to catch “scroll” event. This can be done in the way below. 

  • Declare a function to process the scroll event.
  • Use addEventListener to register the event.
  • Wrap the above inside a useEffect hook.



Floating Bar Example

The source codes are findable in

  • floatingbar.css
  • floatingbar.jsx.


Manipulate the DOM


React is a function-based JS library. It presents a concept of virtual DOM. Does it allow to manipulate the real DOM through document.getElementById and the likes? Yes, let us demonstrate it with the Read More Read Less example.

In this example, clicking Read more button will display the hidden text, and the button’s caption will be updated to Read less. Clicking the button again will make the elements revert to the original state.


Read More Read Less Example

Assign an id to each element that will be manipulated in the example.


HTML Elements

Use document.getElementById to get the elements, and change their attributes properly in response to each click event of the button.


JS Script

React has its own way to do this, namely, using Refs. 

Declare a Ref refbtn using useRef hook and associate it with the button through ref attribute. Then, we can use refbtn.current, a reference to this button, to access it.

For showing or hiding the text, use conditional rendering controlled by two state variables, dotdisplay and isdisplay, respectively. 


 
HTML Elements

JS Script

In the meanwhile, please be noted that directly manipulating the DOM is a workaround outside React’s mechanism. It is handy in some scenarios. On the other hand, it 0probably causes unexpected errors when adding or updating or removing elements. Here is an example stated in React Help, Best practices for DOM manipulation with refs.

The source files are:

  • readmoreless.css
  • readmoreless.jsx


Reference


Manipulating the DOM with Refs 


React - Makeover in React: W3Schools How To

When it comes to building a React app, I get used to searching for a UI library to build the front pages, a straightforward way to achieve f...