Thursday, September 10, 2020

TODO PROJECT IN REACT JS USING ARRAY HOOK, COMPONENT AND SPREAD OPERATOR

 App.jsx

import React, { useState } from "react";
import TodoList from "./TodoList";

const App = () => {

    const [inputTextsetInputText] = useState(""); //Array Hook
    const [listsetList] = useState([]);
    const inputEvent = (event=> {
        setInputText(event.target.value);
    };

    const inputTextList = () => {
        setList((oldLists=> {
            return [...oldListsinputText] //Spread Operator
        });
        setInputText("");
    }

    const deleteText = (id=> {
        console.log("deleted");
        setList((oldLists=> {
            return oldLists.filter((arrEleindex=> {
                return index !== id;
            });
        });
    }

    return (
        <>
            <div className='main_div'>
                <div className='center_div'>
                    <br/><h1>TODO LIST</h1><br/>
                    <input type='text' value={inputText} 
                placeholder='Enter a text' 
                onChange={inputEvent}/>
                    <button onClick={inputTextList}> + </button>
                    <ol>
                    {list.map((valindex=> {
                        return <TodoList key={index} 
                id={index} text={val} onSelect={deleteText}/>
                    })}
                    </ol>                   
                </div>
            </div>
        </>
    );
};

export default App;

TodoList.jsx

import React from "react";

const TodoList = (prop=> {

    return(
        <>
        <div className="todo">
        <i className="fa fa-times" onClick={ () => {
            prop.onSelect(prop.id);
        }}/>
        <li>{prop.text}</li> 
        </div>
        </>
    );
}

export default TodoList;



No comments:

Post a Comment

TODO PROJECT IN REACT JS USING ARRAY HOOK, COMPONENT AND SPREAD OPERATOR

 App.jsx import   React , {  useState  }  from   "react" ; import   TodoList   from   "./TodoList" ; const   App  = ()  ...