홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
jQuery – 스마트폰 스크린 회전 감지 스크립트
5년 전
스마트폰의 스크린이 가로모드와 세로모드를 감지하여 필요에 따라 스타일시트나 스크립트를 다르게 사용하는 경우가 있다.
일단 css의 미디어쿼리로 처리하는 방법을 보면 아래와 같다.

#cover{
   display:none;
}
@media only screen and (device-width: 768px) and (orientation: landscape) {
  #cover{
    display: block;
  }
}

@media only screen and (min-device-width: 320px) and (orientation: landscape) {
  #cover{
    display: block;
  }
}

위 처럼 쓰면 일단 작동이 제대로 되긴 된다. #cover가 사라져있다가 landscape 되는 순간 보여지게 되는 것이다.
그러나 문제는 입력칸에 포커스가 되었을 때다.
이 때 자판이 올라오게 되는데 자판이 올라오면서 화면의 가로 세로 비율이 바뀌게 되고 css에서는 가로모드라 감지하고 #cover 요소가 보이는 코드가 실행이 된다.
즉, 위 코드는 알고보면 가로 :  세로 비율을 갖고 처리하는 것 같다.
그래서 스크립트로 처리하기로 하여 아래와 같이 js 코드를 작성하였다.

$(window).on("orientationchange",function(){
   if(window.orientation == 0) // Portrait
      {
         $('#cover').removeClass('show');
      }
   else // Landscape
      {
         $('#cover').addClass('show');
      }
});

이렇게 하면 화면이 회전하지 않으면 #cover 요소에 show라는 클래스를 지우고, 회전하게 되면 show라는 클래스를 추가하는 스크립트이다.
스타일 시트는 #cover.show 라고 클래스를 가진 경우를 display:block 처리하면 된다.
작동 테스트 결과 아주 잘 작동되고 있다.
입력칸에 포커스가 가도 이상이 없다.
추천추천 : 140 추천 목록
번호 제목
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
3,011
 우클릭 완벽차단 스크립트
3,010
 iframe 높이 100% 맞추기
3,009
 curl 함수를 이용한 HTTP REFERER 변경
3,008
 윈도우10 시스템 파일 및 Dism 검사
3,007
 텍스트 줄바꿈, 글자자르기 CSS
3,006
 jQuery Mobile에서 유용한 코드 10가지.
3,005
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,004
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,003
 [jQuery] jQuery Quick API
3,002
 [ transition ] 링크 hover 색상 변화 속도 조절
3,001
 PHP 5.3.0 에서 사라진 함수들 대체
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.