
CSS 미디어쿼리는 화면의 스타일만을 다루기 때문에, 스크린 크기에 따라 다른 자바스크립트를 적용하는데 한계가 있습니다.
이러한 한계를 극복하게 도와주는 것이 바로 enquire.js 입니다.
이 다음 부분부터는 한가하시면 읽어보세요. :)
자바스크립트 적용에 한계 때문에 처음에 생각해보고, TopSchool 님이 다듬어주신 방법이
스크린 크기가 변경될 때 자바스크립트에서 이벤트핸들러나 클래스를 바꿔치기 해주는 방식입니다.
나중에 알고 보니 거의 일반적으로 쓰이는 방법이더군요.
간단하게 예를 들자면
--- php
기기 감지하는 변수가 이미 선언되어 있고 ($is_mobile)
if ($is_mobile) $event_handler = 'click focus';
else $event_handler = 'mouseover focus';
--- jquery
$(window).resize(function(){
if ($(window).width() == '320') {
$("#sir_gnb").addClass("gnb320");
} else if ($(window).width() == '480') {
$("#sir_gnb").addClass("gnb480");
}
}
$(function(){
$(".gnb320").bind("<?php echo $event_handler; ?>", function() {
// 가로 너비가 320px 일때 모바일과 PC 각각의 효과
}
$(".gnb480").bind("<?php echo $event_handler; ?>", function() {
// 가로 너비가 480px 일때 모바일과 PC 각각의 효과
}
}
--- stylesheet
#sir_gnb.gnb320 {스타일 정의}
#sir_gnb.gnb480 {스타일 정의}
처럼 되는데요.
이 방법과 동일하면서 더 다양한 콜백 기능을 제공해주는 녀석이 enquire.js 입니다.
전체 스크립트 크기도 1kb 도 안 되지만 N스크린 개발에 상당히 유용할 것으로 보이네요.
댓글 3개
게시글 목록
| 번호 | 제목 |
|---|---|
| 11483 | |
| 11481 |
jQuery
깔끔한 탭메뉴 드립니다.
1
|
| 11615 | |
| 11478 | |
| 11477 | |
| 11475 | |
| 11474 |
기타
3단 레이어 소스
|
| 11470 | |
| 11469 |
JavaScript
스크롤바 색깔 바꾸는 스크립트
|
| 11465 | |
| 11464 |
JavaScript
윈도우의 창띄위기 소스입니다.
|
| 11462 |
JavaScript
익스에서 깜박임 글자 구현법
1
|
| 11460 |
JavaScript
자바스크립트를 이용해서 모바일에 selet 박스 구현한것입니다
1
|
| 11458 |
JavaScript
새창띄우는 소스입니다.
1
|
| 11455 | |
| 11452 | |
| 11450 | |
| 11443 |
jQuery
제이쿼리를 이용한 펼침메뉴 1차입니다.
6
|
| 11438 | |
| 11435 |
PHP
메쏘드 static 선언
2
|
| 11433 |
JavaScript
마우스 오버시 이미지 바꾸기
1
|
| 11432 |
JavaScript
일정시간후 스크립트 실행
|
| 11430 |
정규표현식
구글 로봇 접근막기!
1
|
| 11428 |
PHP
시리얼번호생성기
1
|
| 20678 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기