메뉴 건너뛰기

조회 수 300 댓글 2
<!DOCTYPE html>
  <html>
  <head>
  <meta charset="UTF-8">
  <title>이벤트 객체의 target</title>
  <script>
  window.onmouseover = function(e) {
  if(e.target.tagName.toLowerCase() != "span") return;
  e.target.style.textDecoration ="underline";
  }
  window.onmouseout = function(e) {
  if(e.target.tagName.toLowerCase() != "span") return;
  e.target.style.textDecoration ="none";
  }
  </script>
  </head>
  <body>
  <h3>span 태그에만 onmouseover/onmouseout</h3>
  <hr>
  <p>span 태그에 대해서만 <span>마우스</span>가 올라올 때
  밑줄이 그어지고 <span>마우스</span>가 내려갈 때 밑줄이 사라지도록
  <span>자바스크립트 코드</span>를 작성한다.
  </p>
  </body>
  </html>

 

 

빨간글씨인 if() return; 은 책에서 본적이 없는 내용 같아서요.

조건문만 쓴뒤 실행문없이 리턴을 바로 쓰는것엔 어떤 의미가 있나요?

그리고 소문자 체크를 하는 이유는 문제 밑에 힌트의 내용으로는 태그네임 프로퍼티는 항상 대문자라고 하셨는데

태그네임으로 가져오는 프로퍼티는 자바스크립트에서 항상 대문자로 인식을 하기 때문에

우리가 쓰는 소문자랑 체크를 할려면 tolowercase를 써줘야 한다는 말인가요?

 

원래라면

 

function (e){

if(e.target.tagName.toLowerCase() !== span){

e.target.style.textDecoration="none";

}

}

이런식의 코드 작성으로도 되는건가요?

?
  • ?
    관리자 2018.10.24 09:00
    1. e.target은 책 페이지 397, 예제 9-6, 그리고 표 9-2에 있습니다.
    e.target은 현재 이벤트를 유발시킨 DOM 객체입니다. 말씀한 것과 같이 tagName은 모든 DOM 객체가 가진
    프로퍼티로 항상 대문자이지요(표 8-1 참고)

    2. return을 하는 이유는 window 객체에 onmouseover 리스너를 다는 문제이기 때문입니다.
    span 객체에 onmouseover를 달면 굳이 span인지 비교할 필요가 없겠지만, window 객체의 모든 자식 DOM 객체들 위해 마우스가 올라가면 계속
    mouseover 이벤트가 발생하기 때문에, span 객체를 구분하기 위해 아래의 조건문을 사용합니다.
    if(e.target.tagName.toLowerCase() != "span")

    즉 span 객체가 아니라면 바로 리턴하여 아무일도 하지 않기 위함입니다.

    3. tagName이 항상 대문자로 태그이름을 가지고 있기 때문에 이를 소문자로 바꾸기 위해
    e.target.tagName.toLowerCase()를 사용한 것이고 다음과 같이 비교합니다.
    if(e.target.tagName.toLowerCase() != "span")
    다음과 같이 해도 됩니다.
    if(e.target.tagName != "SPAN")

    4. 다음 코드는 좀 이상한 것 같습니다.
    function (e){
    if(e.target.tagName.toLowerCase() !== span) {
    e.target.style.textDecoration="none";
    }
    }

    !== 연산자는 엄격한 비교를 위한 것인데, "span"으로 해야 합니다. 그리고 "none"으로 한 것은
    onmouseout의 코드로 사용해야하는데...

    이상입니다.
  • ?
    muuum 2018.10.25 06:18
    이해가 쏙쏙 됩니다. 감사합니다!

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18280
303 연습문제 8장 이론문제 2번 답을 알고 싶습니다. 1 khe 2017.08.18 814
302 연습문제 5장 10번 문제 질문드립니다. 1 . 2020.10.08 247
301 연습문제 4장 8번문제 1 file 도라에몽 2020.10.02 263
300 연습문제 3장 p.155 5번 문제 1 열심히해보자 2020.10.07 420
299 연습문제 3장 5번 문제 1 seungjun 2023.10.26 129
298 연습문제 3장 2번 질문합니다! 1 file KHE 2022.09.08 152
297 안녕하세요? 186쪽 예제 4-13 대해서 물어봅니다. 1 file 김현우 2020.11.02 125
296 안녕하세요. 몽구스 다른 컴퓨터에서 서버 접속 문의 드립니다. 1 file 2018.03.14 225
295 안녕하세요 처음하는 사람입니다 교재 구입하였습니다 2 성현군 2017.06.29 330
294 안녕하세요 질문드립니다! 2 Hola 2018.10.17 418
293 안녕하세요 관리자님 실습 문제 짝수본 zip 파일은 제공 되지 않는 건가요? 1 문의 2022.02.25 210
292 실제로 사용해봤습니다 ! ㅠㅠ 1 갱자데쓰 2018.02.06 120
291 실습문제답도 제공이 안되는 건가요? 2 아침이 2019.01.07 311
290 실습문제 홀수번 정답 ㅁㅁ 2017.09.24 635
289 실습문제 짝수번 이미지들은 다운할 수 없나요? 공부하면성공한다 2018.10.02 366
288 실습문제 9-8번 질문 있습니다. 2 muuum 2018.10.24 326
» 실습문제 9-7번 답안지를 보고 질문있습니다. 2 muuum 2018.10.23 300
286 실습문제 9-6번 문제중에 5% 증가는 어떻게 해야하나요? 2 muuum 2018.10.24 150
285 실습문제 8장 3번 문제 질문입니다. 2 Joahgng 2018.12.06 261
284 실습문제 8-2 (3) 13412 2018.11.08 15513
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로