HTML table generator in React code challenge

July 22, 2023JavaScript, React

Problem

Generate a table of numbers given the rows and columns.

  1. The user enters the number of rows and columns in a form.
  2. When the form is submitted, a table with the respective number of rows and columns will be generated.
  3. The table contains rows x columns cells.

Preview

This is a preview of the final result:

Table Generator


Solution

Our code is split into two parts: the form and the table. The form is used to get the number of rows and columns from the user. The table is used to display the generated table. We use the useState hook to store the state of the form and the table. When the user clicks the submit button, we generate the table.

Before generating the table we do a check if the number of rows and columns is greater than 0. If it is, we generate the table using generateTable function. We also clear the table if the user changes the number of rows or columns. This is done by setting the table state to null. We use the && (and) operator to conditionally render the table preview.

The table is generated using nested for loops. The outer loop iterates over the rows and the inner loop iterates over the columns. We use the map method to generate the rows and columns. The map method returns an array of React elements. We use the key prop to uniquely identify each element.

The key prop is required when rendering an array of elements.

Finally, we render the table using the tableHTML state.

export default function TableGenerator() {
  const [requiredRows, setRequiredRows] = useState(0);
  const [requiredColumns, setRequiredColumns] = useState(0);
  const [tableHTML, setTableHTML] = useState(null);

  const generateTable = () => {
    if (requiredRows !== 0 && requiredColumns !== 0) {
      setTableHTML(null);

      let rows = [];

      for (let row = 1; row <= requiredRows; row++) {
        let cells = [];

        for (let column = 1; column <= requiredColumns; column++) {
          cells.push(<td key={column}></td>);
        }

        rows.push(<tr key={row}>{cells}</tr>);
      }

      setTableHTML(<tbody>{rows}</tbody>);
    }
  };

  return (
    <div>
      <h2>Table Generator</h2>
      <label>Number of rows</label>
      <input
        type="number"
        value={requiredRows}
        min={1}
        onChange={(e)=> setRequiredRows(Number(e.target.value))}
      />
      <label>Number of columns</label>
      <input
        type="number"
        value={requiredColumns}
        min={1}
        onChange={(e)=> setRequiredColumns(Number(e.target.value))}
      />
      <button onClick={generateTable}>Submit</button>
      {tableHTML && (
        <>
          <h2>Table preview</h2>
          <table>{tableHTML}</table>
        </>
      )}
    </div>
  );
}