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년 전
만들어 주시는 건가요 ㅎㅎㅎ/
게시판 목록
퍼블리셔팁
퍼블리싱과 관련된 유용한 정보를 공유하세요.
질문은 상단의 QA에서 해주시기 바랍니다.
질문은 상단의 QA에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 737 | CSS |
kiplayer
|
11년 전 | 16454 | |
| 736 | HTML |
|
11년 전 | 7101 | |
| 735 | CSS |
잘살아보자
|
11년 전 | 5795 | |
| 734 | CSS |
잘살아보자
|
11년 전 | 4523 | |
| 733 | CSS |
잘살아보자
|
11년 전 | 6778 | |
| 732 | HTML |
잘살아보자
|
11년 전 | 4716 | |
| 731 | CSS |
잘살아보자
|
11년 전 | 9436 | |
| 730 | 기타 |
잘살아보자
|
11년 전 | 3485 | |
| 729 | HTML |
잘살아보자
|
11년 전 | 7651 | |
| 728 | 기타 |
|
11년 전 | 6805 | |
| 727 | 기타 | 11년 전 | 11471 | ||
| 726 | 기타 |
|
11년 전 | 5477 | |
| 725 | 기타 |
네이비칼라
|
11년 전 | 4382 | |
| 724 | CSS |
잘살아보자
|
11년 전 | 4892 | |
| 723 | CSS |
잘살아보자
|
11년 전 | 6607 | |
| 722 | CSS |
잘살아보자
|
11년 전 | 17074 | |
| 721 | CSS |
|
11년 전 | 7164 | |
| 720 | 기타 | 11년 전 | 3763 | ||
| 719 | 기타 | 12년 전 | 7328 | ||
| 718 | CSS | 12년 전 | 10521 | ||
| 717 | 반응형 | 12년 전 | 6134 | ||
| 716 | 반응형 | 12년 전 | 14556 | ||
| 715 | 기타 | 12년 전 | 7320 | ||
| 714 | CSS | 12년 전 | 5040 | ||
| 713 | 반응형 | 12년 전 | 30115 | ||
| 712 | 기타 | 12년 전 | 5273 | ||
| 711 | HTML |
kiplayer
|
12년 전 | 10878 | |
| 710 | CSS | 12년 전 | 15283 | ||
| 709 | 웹접근성 | 12년 전 | 6733 | ||
| 708 | 웹접근성 | 12년 전 | 6052 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기