N스크린 개발에 유용한 framework enquire.js

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개
12년 전
글이 사라졌길래 지우셨나 했는데, 여기로 왔군요. ^^
js를 이용한 스크린 크기별 class 할당 방식이 '아주' 일반적인 것은 아닐겁니다.
이 방식을 일반화해서 라이브러리로 만드셔도 괜찮을것 같은데요? ^^
js를 이용한 스크린 크기별 class 할당 방식이 '아주' 일반적인 것은 아닐겁니다.
이 방식을 일반화해서 라이브러리로 만드셔도 괜찮을것 같은데요? ^^
12년 전
저도 라이브러리화 되었으면 좋겠어요! ㅠㅠ
lainfox
11년 전
만들어 주시는 건가요 ㅎㅎㅎ/
게시글 목록
| 번호 | 제목 |
|---|---|
| 26560 | |
| 24588 | |
| 31642 | |
| 31638 | |
| 31633 | |
| 31630 | |
| 31625 | |
| 19452 | |
| 6719 |
개발자
개발자님 찾아요
|
| 6718 |
개발자
제작자구합니다~
|
| 6717 |
개발자
개발자님 구해요
|
| 6715 |
개발자
비용과 기간문의
1
|
| 27797 | |
| 30907 | |
| 30904 | |
| 6714 | |
| 6713 | |
| 27791 | |
| 19450 |
JavaScript
제니퍼소프트, UI 소스 오픈 하여군요
1
|
| 6712 | |
| 6711 | |
| 6709 | |
| 6708 | |
| 27790 | |
| 19447 |
jQuery
좋은... swipe 스크롤
2
|
| 6706 | |
| 6703 | |
| 6702 | |
| 6701 | |
| 6697 | |
| 6692 | |
| 27783 | |
| 6691 | |
| 6687 | |
| 6685 | |
| 6683 | |
| 6682 | |
| 19446 | |
| 27770 | |
| 19445 | |
| 27768 | |
| 6681 | |
| 6675 | |
| 6674 | |
| 19444 |
jQuery
swipe 좌우스크롤
|
| 6672 | |
| 6671 | |
| 27761 | |
| 6670 | |
| 30900 | |
| 24585 | |
| 6660 | |
| 6655 | |
| 6653 | |
| 31624 |
홈페이지기초
HTML과정 - 20. HTML colors
|
| 6651 | |
| 31623 |
홈페이지기초
HTML과정 - 19. HTML iframes
|
| 31621 |
홈페이지기초
HTML과정 - 18. HTML forms
1
|
| 19443 |
MySQL
MYSQL 오늘 날짜 뽑아오기
|
| 6650 | |
| 31620 |
홈페이지기초
HTML과정 - 17. HTML layout
|
| 31619 |
홈페이지기초
HTML과정 - 16. HTML blocks
|
| 31612 |
홈페이지기초
HTML과정 - 15. HTML lists
6
|
| 31611 |
홈페이지기초
HTML과정 - 14. HTML tables
|
| 27746 | |
| 31605 |
홈페이지기초
HTML과정 - 13. HTML images
5
|
| 6648 | |
| 20781 | |
| 31603 | |
| 31600 |
홈페이지기초
HTML과정 - 11. HTML head
2
|
| 6645 | |
| 6643 | |
| 6642 | |
| 6640 | |
| 20777 | |
| 31597 |
홈페이지기초
HTML과정 - 10. HTML Links
2
|
| 6637 | |
| 19442 | |
| 31594 | |
| 31591 | |
| 31589 | |
| 31586 | |
| 31584 |
홈페이지기초
HTML과정 - 5. HTML 속성
1
|
| 20758 | |
| 19440 | |
| 31575 |
홈페이지기초
HTML과정 - 4. HTML 엘리먼트
8
|
| 31567 |
홈페이지기초
HTML과정 - 3. HTML 기초 예제들
7
|
| 20747 | |
| 6636 | |
| 31563 | |
| 31552 |
홈페이지기초
HTML과정 - 1. HTML이 무엇인가?
10
|
| 27743 | |
| 24579 | |
| 6630 | |
| 6628 | |
| 6620 | |
| 6617 | |
| 27732 | |
| 24577 | |
| 6616 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기