img가 로드가 안될때 기본이미지를 보여주고 싶을때 onerror를 사용합니다.
<img src="기본이미지.png" alt="대체텍스트" onerror="this.src='대체이미지.png';" />
이런식으로 사용을 하는데; 문제는 validator 에서 onerror은 에러로 뱉어내버리죠…
그냥 안쓰거나 밸리데이터 따위 무시해주면 되겠지만 onerror도 사용하고 밸리데이터도 통과해야하는 경우가 얼마든지 있을수있죠.
그래서 그냥 이벤트를 자바스크립트로 등록하는것을 만들어봤습니다.
핵심은 IE와 IE외의 브라우저가 이벤트 등록하는것이 다르다는것입니다.
IE의경우에는 attachEvent 를 이용해서 onerror를 등록하고 일어난이벤트의 srcElement의 src값을 변경해주면 됩니다.
"이미지DOM".attachEvent("onerror",function(e) { e.srcElement.src ="images/pic_noimg.gif"})
그외 Opera, FF, safari, chrome 에서는
"이미지DOM".onerror = function(e) { e.target.src = "images/pic_noimg.gif";};
이렇게 해주니 되더라구요. 사실 addEventListener를 사용해볼까 했었는데 귀찮아서 패스=_=
그럼 이만(제목에 비해 겁네 포스팅이 허접하군요=_=/ )