Skip to Content
Go Back
안형우

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

📌 CSS가 어려운 이유 — 프로젝트 중심 실전 CSS 강의 소개 2023-04-13
📌 워드프레스, 답답한 빌더와 플러그인 대신 시원하게 커스터마징하기(강의) 2023-01-15
📌 아무도 말하지 않는 PHP의 좋은 점 2018-10-13
📌 유지보수하기 쉬운 CSS 전략(슬라이드) 2016-12-20
📌 워드프레스 테마에서 템플릿 파일 매칭 순서 2013-05-12
📌 [번역] CSS 코드 냄새 2013-01-01

[javascript/jQuery] 키보드로 이벤트 핸들링할 때 input과 textarea에서 작동하지 않도록 만들기

좀 노가다를 하는 방법은 input과 textarea에 들어갈 때마다 이벤트를 해제하는 것인 듯하다.

jQuery event.target 객체를 사용하기

두 번째 방법은 jQuery를 사용할 경우 쓸 수 있는 방법인 듯하다.

jQuery에서 event.target 객체를 제공하는 것 같다.

그러면 이런 식으로 코드를 사용할 수 있다.(크롬, 파폭, IE7에서 각각 테스트했다.)

$(document).keydown(function(e){
	if(e.target.nodeName.toLowerCase() == 'input'
		|| e.target.nodeName.toLowerCase() == 'textarea'){
		//input과 textarea에서는 아무것도 하지 않는다.
	}else{
		$('body').prepend(123);
	}
});

플래인 자바스크립트의 경우

플래인 자바스크립트를 이용하는 경우, 다음 코드를 참고할 수도 있을 듯하다.(이 코드는 파폭에서 작동하지 않는다.)

var key = new Array();
key['a'] = "이동할 주소";
key['b'] = "이동할 주소";
key['c'] = "이동할 주소";
key['d'] = "이동할 주소";

function getKey(keyStroke) {
    if ( (event.srcElement.tagName != 'INPUT') && (event.srcElement.tagName != 'TEXTAREA') ) {
        isNetscape=(document.layers);
        eventChooser = (isNetscape) ? keyStroke.which : event.keyCode;
        which = String.fromCharCode(eventChooser).toLowerCase();
        for (var i in key)
            if (which == i) window.location = key[i];
    }

[출처] 라이프인사이드 – 출처 바로 가기(링크 사라짐)

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다