Как ограничить список отображаемых данных для определенного списка в react js

#reactjs #react-hooks

Вопрос:

Я пытаюсь создать приложение, в котором, когда пользователь нажимает кнопку «Создать», создается вопрос опроса с четырьмя ответами. Цель состоит в том, чтобы в одном списке пользователь мог добавить максимум 4 вопроса и минимум 1 вопрос. Поэтому, когда пользователь пытается добавить еще один вопрос после 4-го вопроса, должен быть создан новый список опросов. Таким образом, один список опросов может содержать максимум четыре вопроса.

 //Survey.js

import React, { useState, useEffect } from "react";
import { Fragment } from "react";
import "./Survey.css";
import CreateSurvey from "../modals/CreateSurvey";
import Card from "../card/Card";

const Survey = () => {
  const [modal, setModal] = useState(false);
  const [surveyList, setSurveyList] = useState([]);

  useEffect(() => {
    let arr = localStorage.getItem("surveyList");
    if (arr) {
      let obj = JSON.parse(arr);
      setSurveyList(obj);
    }
  }, []);

  // const surveyListArray = [];
  // while (surveyList.length > 0) {
  //   surveyListArray.push(surveyList.splice(0, 3));
  // }

  const deleteSurvey = (index) => {
    let tempList = surveyList;
    tempList.splice(index, 1);
    localStorage.setItem("surveyList", JSON.stringify(tempList));
    setSurveyList(tempList);
    window.location.reload();
  };

  const toggle = () => {
    setModal(!modal);
  };

  const updateListArray = (obj, index) => {
    let tempList = surveyList;
    tempList[index] = obj;
    localStorage.setItem("surveyList", JSON.stringify(tempList));
    setSurveyList(tempList);
    window.location.reload();
  };

  const saveSurvey = (surveyObj) => {
    let tempList = surveyList;
    tempList.push(surveyObj);
    localStorage.setItem("surveyList", JSON.stringify(tempList));
    setSurveyList(surveyList);
    setModal(false);
  };
  return (
    <Fragment>
      <div className="header text-center">
        <h5>Survey</h5>
        <button className="btn btn-primary" onClick={() => setModal(true)}>
          Create Survey
        </button>
      </div>
      <div className="survey-container">
        {surveyList amp;amp;
          surveyList.map((obj, index) => (
            <Card
              surveyObj={obj}
              index={index}
              deleteSurvey={deleteSurvey}
              updateListArray={updateListArray}
            >
              <input type="radio" name="answerOne" />
            </Card>
          ))}
      </div>
      <CreateSurvey toggle={toggle} modal={modal} save={saveSurvey} />
    </Fragment>
  );
};

export default Survey;
 

//Card.js

 import React, { useState } from "react";
import "./Card.css";
import EditSurvey from "../modals/EditSurvey";

const Card = ({ surveyObj, deleteSurvey, index, updateListArray }) => {
  const [modal, setModal] = useState(false);

  const toggle = () => {
    setModal(!modal);
  };

  const updateSurvey = (obj) => {
    updateListArray(obj, index);
  };

  const deleteHandler = () => {
    deleteSurvey(index);
  };

  return (
    <div>
      <div className="card-wrapper mr-5">
        <div className="card-top"></div>
        <div className="survey-holder">
          <span className="card-headers">{surveyObj.name}</span>
          <span className="check">
            <input type="radio" className="radio" />
            <p className="answer"> {surveyObj.answerOne}</p>
          </span>
          <span className="check">
            <input type="radio" className="radio" />
            <p className="answer"> {surveyObj.answerTwo}</p>
          </span>
          <span className="check">
            <input type="radio" className="radio" />
            <p className="answer"> {surveyObj.answerThree}</p>
          </span>
          <span className="check">
            <input type="radio" className="radio" />
            <p className="answer"> {surveyObj.answerFour}</p>
          </span>
          <div className="icons">
            <i className="far fa-edit edit" onClick={() => setModal(true)}></i>
            <i className="fas fa-trash-alt delete" onClick={deleteHandler}></i>
          </div>
        </div>
        <EditSurvey
          modal={modal}
          toggle={toggle}
          updateSurvey={updateSurvey}
          surveyObj={surveyObj}
        />
      </div>
    </div>
  );
};

export default Card;
 

//CreateSurvey.js

 import React, { useState } from "react";
import { Button, Modal, ModalHeader, ModalBody, ModalFooter } from "reactstrap";
import { Fragment } from "react";

const CreateSurvey = ({ modal, toggle, save }) => {
  const [question, setQuestion] = useState("");
  const [answerOne, setAnswerOne] = useState("");
  const [answerTwo, setAnswerTwo] = useState("");
  const [answerThree, setAnswerThree] = useState("");
  const [answerFour, setAnswerFour] = useState("");

  const changeHandler = (e) => {
    const { name, value } = e.target;

    if (name === "question") {
      setQuestion(value);
    } else if (name === "answerOne") {
      setAnswerOne(value);
    } else if (name === "answerTwo") {
      setAnswerTwo(value);
    } else if (name === "answerThree") {
      setAnswerThree(value);
    } else {
      setAnswerFour(value);
    }
  };

  const saveHandler = (e) => {
    e.preventDefault();
    let surveyObj = {};
    surveyObj["name"] = question;
    surveyObj["answerOne"] = answerOne;
    surveyObj["answerTwo"] = answerTwo;
    surveyObj["answerThree"] = answerThree;
    surveyObj["answerFour"] = answerFour;
    save(surveyObj);
  };
  return (
    <Fragment>
      <Modal isOpen={modal} toggle={toggle}>
        <ModalHeader toggle={toggle}>Create a Survey Question</ModalHeader>
        <ModalBody>
          <form>
            <div>
              <div className="form-group">
                <label>Survey Questions</label>
                <input
                  type="text"
                  className="form-control"
                  value={question}
                  name="question"
                  onChange={changeHandler}
                />
              </div>
            </div>
            <div className="mt-2">
              <label>Survey Answers</label>
              <div className="form-group">
                <label>Answer 1</label>
                <input
                  type="text"
                  className="form-control mt-2 mb-2"
                  value={answerOne}
                  name="answerOne"
                  onChange={changeHandler}
                />
              </div>
              <div className="form-group">
                <label>Answer 2</label>
                <input
                  type="text"
                  className="form-control mt-2 mb-2"
                  value={answerTwo}
                  name="answerTwo"
                  onChange={changeHandler}
                />
              </div>
              <div className="form-group">
                <label>Answer 3</label>
                <input
                  type="text"
                  className="form-control mt-2 mb-2"
                  value={answerThree}
                  name="answerThree"
                  onChange={changeHandler}
                />
              </div>
              <div className="form-group">
                <label>Answer 4</label>
                <input
                  type="text"
                  className="form-control mt-2 mb-2"
                  value={answerFour}
                  name="answerFour"
                  onChange={changeHandler}
                />
              </div>
            </div>
          </form>
        </ModalBody>
        <ModalFooter>
          <Button color="primary" onClick={saveHandler}>
            Create
          </Button>
          <Button color="secondary" onClick={toggle}>
            Cancel
          </Button>
        </ModalFooter>
      </Modal>
    </Fragment>
  );
};

export default CreateSurvey;
 

Комментарии:

1. Это во многом зависит от того, чего вы хотите в своем пользовательском опыте. Когда вы говорите это a new survey list should be created , вы имеете в виду, что пользователь не сможет создавать больше и заставит его сохранить, прежде чем продолжить, или он введет N вопросов, и ваш веб-сайт сделает трюк, чтобы разделить опросы на несколько. Это зависит

2. Возможно ли, чтобы приложение выполнило трюк, разделившись на несколько опросов максимум по четырем вопросам? На самом деле я думал о том, чтобы заставить пользователя сохранить. Но сейчас я бы предпочел другое. Не могли бы вы, пожалуйста, подсказать мне, как это сделать. Спасибо

3. Ваш код работает не так, как вы описываете в своем вопросе. Поскольку пользователь не может добавить более одного вопроса, я прав? Если это правда, то нет никаких проблем, я просто хочу понять, на что мы смотрим, чтобы знать, как помочь

4. В настоящее время пользователь может добавить к n количество вопросов, поэтому я хочу ограничить максимум 4 вопросами для каждого списка и минимум 1