메뉴 건너뛰기

2022.05.17 14:57

9장 실습문제3번

조회 수 194 댓글 2

개정판 410page 9-9에서는 매개변수를 사용하지 않았는데

실습문제 3번같은 경우는 calculate(event)를 사용해야 하는 이유가 있을까요?

그리고 event는 다른걸로 대체가 안되나요?

 

function calculate(e){
    if(e.key == "Enter") {
        let exp = document.getElementById("exp");
        let result = document.getElementById("result");
        result.value = eval(exp.value);
    }

<form>
식 <input type="text" id="exp" value="" onkeydown="calculate(event)"><br>
값 <input type="text" id ="result"> 
</form>

?
  • ?
    관리자 2022.05.18 12:38

    1) W3C 표준에서 이벤트가 발생하면, 발생한 이벤트의 타입 등의 정보를 가진 이벤트 객체가 생성되며 이 객체가 이벤트 리스너의 첫번째 매개변수로 전달됩니다. 그러므로 다른 함수에 이벤트 객체를 전달하려면 첫번째 매개 변수를 전달해야 합니다. 실습문제 3에서는 onclick = calculate(event) 라는 코드를 통해 브라우저로부터 event 라는 이름의 변수로 이벤트 객체를 전달받았습니다.

    2) 그런데 예제 9-9의 경우
    역시 버튼이 클릭되면 이벤트가 발생하고 이벤트 객체가 생성됩니다. 그런데 이 사례에서는 굳이 이벤트를 사용하지 않고 calculate()를 호출하는 것으로 처리하였습니다.
    왜냐하면 발생한 이벤트의 타입이나 눌러진 키 값 들의 정보가 필요없기 때문입니다.

    3) 하지만, 실습문제 3의 경우, 임의의 키를 누르면 이벤트가 발생하지만,
    엔터기를 누른 경우에만 처리해야하기 때문에 발생한 이벤트에 관한 정보를 가진 이벤트 객체가 필요합니다.
    그래서 calculate(event)를 통해 현재 발생한 이벤트 객체를 가리키는 event 변수를 calculate(e) 함수에 전달하고 함수에서는 e를 이용하여 어떤 키가눌러졌는지 알게 되는 겁니다.

    4) 역사적인 이유때문에, 마이크로소프트 사는 W3C의 웹 국제 표준과 달리 처리하는 방법이 있었기 때문에 W3C 방법외에 이벤트 객체를 다루는 다른 방법을 제공합니다.
    마이크로소프트에 개발 배포하는 브라우저 들은 이벤트가 발생하는 경우, window.event라는 전역변수가 이벤트 객체를 가리키도록 합니다.
    그래서 이들 브라우저에서는(혹은 마이크로소프트사의 브라우저와 호환성을 가지도록 작성한 다른브라우저에서도, 하지만 장담할 수 없습) 다음과 같이 작성해도 됩니다.
    function calculate(){
    if(window.event.key == "Enter") {
        let exp = document.getElementById("exp");
        let result = document.getElementById("result");
        result.value = eval(exp.value);
    }

    <form>
    식 <input type="text" id="exp" value="" onkeydown="calculate()"><br>
    값 <input type="text" id ="result">
    </form>

    하지만, 우리는 w3C의 국제 표준에 맞추어 코딩해야 세상의 모든 브라우저에서 실행될 것입니다.

  • ?
    열공이 2022.05.21 15:55
    교수님~상세한 설명 감사합니다. 짱~!

QnA

공부하면서 궁금했던 것을 질문해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18304
382 2장 예제 2-11과 관련하여 질문 드립니다. 1 조근석 2017.04.30 398
381 7장에 연습문제에 있는 실습문제 질문 1 student 2017.05.07 1261
380 8장 연습문제 실습문제 4장 2 student 2017.05.08 2873
379 실습문제 7장에 8번 질문 1 abcd 2017.05.09 994
378 오랜만에 찾아 뵙습니다.. 3 은성 2017.05.10 338
377 9장 오픈챌린지 답이 너무 궁금합니다. 1 범이 2017.05.10 1253
376 8장의 10번 문제 질문 있습니다. 웸프로그래밍 2017.05.28 625
375 9장 2번 질문있습니다. 웹프로그래밍 2017.05.28 1136
374 9장 4번 질문있습니다. 웹프로그래밍 2017.05.28 551
373 4장 8번 문제 질문드려요! 1 file safd 2017.06.09 683
372 07장 10번 답좀 알고싶습니다... 2 abcd 2017.06.11 1088
371 안녕하세요 처음하는 사람입니다 교재 구입하였습니다 2 성현군 2017.06.29 330
370 7장 10번문제 1 학섕 2017.07.12 1868
369 연습문제 8장 이론문제 2번 답을 알고 싶습니다. 1 khe 2017.08.18 818
368 예제에 필요한 그림이나 동영상 같은 자료파일은? 1 donghee 2017.09.15 130
367 6장 실습문제 짝수 답좀 알려주실분? 제발요  도움 2017.09.18 1105
366 예제에 나오는 이미지와 동영상파일은 어디서 다운받을 수 있나요... 1 gofkdvjvl 2017.09.21 215
365 실습문제 홀수번 정답 ㅁㅁ 2017.09.24 635
364 예제 5-11을 하다 사소한 궁금한 것이 생겼습니다 1 수소방울 2017.10.13 167
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로