React Form and Array example

In this tutorial, we’re gonna build a simple React Application that shows an Array of items submitted from a Form.

Related Posts:
React Hello World example
React Simple Data Binding example

I. Technologies

– React 16
– NodeJs 6.11.2
– NPM 3.10.10
– Yarn 1.5.1
– Babel 6.24.1

II. Practice

1. Goal

We will build a React Application that can receive data from a form submission, then display them as a list:


2. Project Structure


3. Step by Step
3.0 Set up Environment

We need NodeJs, Yarn and Babel to compile and run this example.
Please visit Set up Environment for step by step.

3.1 Set up Project folder

Create folder for BindData project, then make subfolders and subfiles like this:

3.2 Dependency

Open package.json, write these lines for project information and dependency:

3.3 index.html

This is the default HTML file that appears in the browser when we invokes our application.
We also use this HTML file to embed React files and reference to our javascript app.js.

div tag with id="app" for rendering template in the next step.

3.4 app.js

– Firstly, we create a Form element with onSubmit event that invokes submit() function for submission, data is the element name that we will use for getting value inside submit() function:

– Inside submit() function with event as input parameter:
+ We call preventDefault() event method to make default action that belongs to the event not occur.
+ We get data from form submission by
+ Then we add the data value to categories array using array.push(value).
+ We also need to re-render template for updating UI.

– Use map() method to iterate array items:

3.5 Run & Check result

– Point cmd to project folder, then run cmd: yarn install.
node_modules folder and yarn.lock file now appear in our project folder:


– Run cmd: babel src/app.js --out-file=public/scripts/app.js --presets=env,react --watch
Now, a new app.js file appear in public/scripts folder, code insides this file was generated automatically (and also update automatically whenever we modify and save src/app.js).

– Open new cmd, point to Project folder, run cmd: live-server public.
Result in Browser:


III. Source code


By grokonez | March 27, 2018.

Related Posts

Got Something To Say:

Your email address will not be published. Required fields are marked *