• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 React 게시판 리액트에서 div안의 value값은 사용못하나요?

리액트에서 div안의 value값은 사용못하나요?

7 글 보임 - 1 에서 7 까지 (총 7 중에서)
  • 글쓴이
  • #33880

    고진규
    참가자

    <textarea className='text1' placeholder="코드써라." id='code' value={code} onChange={(e) => setCode(e.target.value)} />

     

    이런식으로 버튼을 누르면 value를 api로 보내는걸 성공해서 

    ----------------------------------------------------------------------------------------------------

    const [language_name, setLanguage_name] = useState("PYTHON")

    const [language, setLanguage] = useState(0)

    <div className="col dropdown-item" id='language' onClick={() => { setLanguage_name('PYTHON'); setLanguage(0); }} value={language}>PYTHON</div>

    위와 똑같이  div를 누르면 데이터에 api로 전송할려고했는데

    value가 안가는거같습니다.  다른 방법이 있을까요?

    #33899

    codingapple
    키 마스터

    value 속성은 <input> 류에만 사용가능합니다

    state에 이미 저장된데이터같은데 굳이 value에 넣어둘 필요가 있을까요

    #33910

    고진규
    참가자

    app.js 에

    const [language, setLanguage] = useState(0)

    있고

     

    aa.js에

    function MakeFunc(props) {
    const Bearer="Bearer "
    const code = document.getElementById("code");
    const function_name = document.getElementById("function_name");
    axios({
    method: "POST",
    headers:{
    Authorization: Bearer+localStorage.getItem("ac-token")
    },
    url: "비밀",
    data: {
    "code": code?.value,
    "function_name": function_name?.value,
    "language":############################<- 이부분에 들어가야하는데 어떻게 해야할지 모르겠습니다..
    }
    }).then((res) => {
    console.log(res);
    console.log(props.language)
    }).catch(error => {
    console.log(error);
    console.log(props.language)
    });
    }
    export default MakeFunc;

     

    props를 써야할거같은데

     

    app.js에

    <aa language={language}/>를 해봤는데 그냥 흰화면이 나와서..

    #33911

    고진규
    참가자

    props는 부모 자식관계에 쓰는걸로아는데 제가 지금쓸려는 상황은 부모자식관계가 아닌거같은데 어떻게해야하나요?

    #33926

    codingapple
    키 마스터

    MakeFunc 함수는 컴포넌트가 아니라 일반함수같은데 

    MakeFunc(language)

    이러면 파라미터로 원하는 변수 함수안으로 전송가능합니다

    함수안에선 props 출력해보면 language 값이 나오겠군요 

    #33934

    고진규
    참가자

     

    a.js

    function Translation() {

    const [language_name, setLanguage_name] = useState("PYTHON")
    const [language, setLanguage] = useState(0)
    return (

    <div className="col dropdown-item" onClick={() => { setLanguage_name('RUBY'); setLanguage(3); }} >RUBY</div>
    <div className="col dropdown-item" onClick={() => { setLanguage_name('GO'); setLanguage(4); }} >GO</div>
    <div className="col dropdown-item" ></div>
    }

     

    makeFunc.js

    function MakeFunc(language) {
    const Bearer="Bearer "
    const code = document.getElementById("code");
    const function_name = document.getElementById("function_name");
    axios({
    method: "POST",
    headers:{
    Authorization: Bearer+localStorage.getItem("ac-token")
    },
    url: "비밀 ",
    data: {
    "code": code?.value,
    "function_name": function_name?.value,
    "language":language.  ->수정
    }
    }).then((res) => {
    console.log(res);
     
    }).catch(error => {
    console.log(error);

    });
    }
    export default MakeFunc;

     

    이런식 맞나요..?  제가이해를 못했습니다 ㅠ.ㅠ.

    #33940

    codingapple
    키 마스터

    네 이제 버튼누르면 MakeFunc(서버로보낼값); 실행하면 되겠군요

7 글 보임 - 1 에서 7 까지 (총 7 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관, 개인정보처리방침
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠