팁이라고 쓰고 꼼수라고 읽는...
다른 작업에 밀려서 머리 속으로 고민만 하던 것이 실제 구현을 해보니 의외로 빨리 풀렸습니다.
고민 과정에서 언제나 조언 주시고 도움 주신 전진님께 다시 한번 감사드립니다. :)
jquery 는 g4s 에서 사용 중인 1.8.3 버전을 기준으로 작업했습니다.
하이브리드 개발자님과 의논해보니, 이벤트핸들러 말고 클래스 바꿔치기도 되겠습니다.
<!doctype html>
<html lang="ko">
<head>
<meta charset="utf-8">
<title>테스트</title>
<meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=0,maximum-scale=10,user-scalable=yes">
<meta name="HandheldFriendly" content="true">
<meta name="format-detection" content="telephone=no">
<script src="js/jquery-1.8.3.min.js"></script>
<style>
ul {margin:0;padding:0;list-style:none}
ul ul {display:none}
button {cursor:pointer}
</style>
</head>
<body>
<p></p>
<ul>
<li>
<button type="button">테스트</button>
<ul>
<li>
<a href="">테스트 서브</a>
</li>
</ul>
</li>
</ul>
<script>
// 무엇을 구현할 것인가?
// gnb
// 구조는 어떤가?
// ul > li > button
// ul > li > a
// 어떻게 동작하는가?
// min-width 970px 에서 button 클릭 시 페이지 이동 (script 이용하여 event 추가)
// 오버/포커스 시 서브메뉴 출력
// max-width 969px 에서 button 클릭 시 서브메뉴 출력
// PC 모바일을 검사하여 PC 면 + 포커스 오버 시 서브메뉴 출력 및 클릭해도 페이지 이동은 하지 않음 (예정)
$(function() {
$(window).load(function(){
var doc_width = document.width; // 문서 로드될 때 문서 넓이 감지
hdlr_switch(doc_width);
});
$(window).resize(function(){
var doc_width = document.width; // 리사이즈 될 때 문서 넓이 감지
hdlr_switch(doc_width);
});
function hdlr_switch(val) {
var hdlr = "";
if (val >= "970") {
hdlr = "mouseover focus";
} else {
hdlr = "click";
}
$("button").unbind();
$("button").bind(""+hdlr+"", function(){
$("ul ul").css("display", "block");
});
/* 970px 이상일 때만
$("button").click(function(){
$(location).attr('href','http://www.sir.co.kr');
});
*/
}
});
</script>
</body>
</html>
댓글 20개
사이즈로 이벤트를 체크하셨으니
if (val >= "970") {
hdlr = "mouseover focus";
} else {
hdlr = "click";
}
3개 다선언해도 콜백 함수에 사이즈를 지정하면 된다는 말이였어요^^
지운아빠님의 방식은 화면 사이즈가 변경될때마다 리소스가 발생되서 부담이 될수있다는걸 표현해서 임의로 말한거구요
제가 하는 방식은 마우스를 오버하거나 클릭 하는 순간에만 체크하기위한거구요
정확히 소스를 짠건아니구요
대략 저런식으로하면 부화적인 면에서도 좋다.. 라는 말을 한거예용
정확하게 하려면 아래처럼 리턴을 하거나 아니면 동작되는 css를 안넣으면되겠죠
if(e.type == "mouseover")
return;
if (val >= "970") {
hdlr = "mouseover focus";
} else {
hdlr = "click";
}
3개 다선언해도 콜백 함수에 사이즈를 지정하면 된다는 말이였어요^^
지운아빠님의 방식은 화면 사이즈가 변경될때마다 리소스가 발생되서 부담이 될수있다는걸 표현해서 임의로 말한거구요
제가 하는 방식은 마우스를 오버하거나 클릭 하는 순간에만 체크하기위한거구요
정확히 소스를 짠건아니구요
대략 저런식으로하면 부화적인 면에서도 좋다.. 라는 말을 한거예용
정확하게 하려면 아래처럼 리턴을 하거나 아니면 동작되는 css를 안넣으면되겠죠
if(e.type == "mouseover")
return;
그냥 글만보고 때린거라 의미적으로 담은거라 설명이 미흡했네요 정확한 코드는
$("button").bind("mouseover click", function(e){
//alert(e.type);
if($(window).width() >= "970" && e.type == "mouseover"){
$("p").html("970px 보다"+ $(window).width() + "이기 때문에 오버로 동작 css");
}else if($(window).width() < "970" && e.type == "click"){
$("p").html("970px 보다 작은"+ $(window).width() + "이기 때문에 클릭으로 동작 css");
}
});
테스트 사이트
http://huddak.net/aa.php
목표는 반응형웹에서 해상도별로 클래스를 조정이 가능하다.
근데 스크립트가 들어가니까 요런식으로하면 스크립트 부분에서 더 효율적이지 않겠냐
이걸 말한거였어요
$("button").bind("mouseover click", function(e){
//alert(e.type);
if($(window).width() >= "970" && e.type == "mouseover"){
$("p").html("970px 보다"+ $(window).width() + "이기 때문에 오버로 동작 css");
}else if($(window).width() < "970" && e.type == "click"){
$("p").html("970px 보다 작은"+ $(window).width() + "이기 때문에 클릭으로 동작 css");
}
});
테스트 사이트
http://huddak.net/aa.php
목표는 반응형웹에서 해상도별로 클래스를 조정이 가능하다.
근데 스크립트가 들어가니까 요런식으로하면 스크립트 부분에서 더 효율적이지 않겠냐
이걸 말한거였어요
게시글 목록
| 번호 | 제목 |
|---|---|
| 12413 | |
| 12412 | |
| 12411 |
JavaScript
실시간 카운트 다운 시계 입니다.
|
| 12410 |
jQuery
jQuery, 이미지맵 마우스오버시 하이라이트 표시
|
| 12407 | |
| 12406 | |
| 12405 | |
| 12404 |
JavaScript
한번만 submit 되게 하기 입니다.
|
| 12403 |
JavaScript
영문자나 숫자만 입력 할 수 있게 하기 입니다.
|
| 12402 |
JavaScript
현재 페이지 이메일로 보내는 버튼 만들기 입니다.
|
| 12401 |
JavaScript
모바일웹에서 PC버전 링크
|
| 12400 |
JavaScript
특정 파일형태만 업로드 하기 입니다.
|
| 12399 |
JavaScript
입력 문자열 앞에 붙는 공백 제거하기 입니다.
|
| 12398 |
JavaScript
키보드 방향키로 창의 위치를 이동시키기 입니다.
|
| 12397 | |
| 12396 | |
| 12395 |
JavaScript
키보드 눌러 이동하는 단축키 사용하기 입니다.
|
| 12394 |
JavaScript
책장을 넘기는 것같은 이미지 슬라이드 쇼 입니다.
|
| 12393 |
JavaScript
마우스를 대면 링크 이미지들을 보여주기 입니다.
|
| 12392 |
PHP
pushbullet 푸시 발송
|
| 12391 |
MySQL
같은 컬럼의 행들을 한번에 UPDATE 하기
|
| 12390 |
JavaScript
이미지들을 보여주는 풀다운 콤보메뉴 입니다.
|
| 12389 |
JavaScript
부드럽게 오버랩되는 이미지 슬라이드 쇼 입니다.
|
| 12388 |
JavaScript
끊김없이 연속적으로 스크롤 되는 이미지 스크롤러 입니다.
|
| 12387 |
PHP
php 주요 정리 입니다.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기