어제 다평정님을 위해 짜드렸던 드랍다운 예제에 jQuery 효과를 하나 넣어보도록 하겠습니다.
어제 예제는 마우스 오버 (hover) 시 하위메뉴가 펼쳐지는데, 이게 툭하고 나타나니 퉁명스럽죠. 이걸 부드럽게 나타내는 효과를 넣어 보도록 하겠습니다.
어제는 css 에서 display: none 으로 감춰져 있다가 마우스 오버시 (hover) 이 감춰진게 보여지도록 했는데, 여기에 css transition 효과를 넣으면, 이걸 부드럽게 나타다도록 보여지게 할수 있지만, 빌어먹을 IE 땜에, 이 효과를 IE 에서도 보여지게 해주려면 jQuery 를 사용하는 수 밖에 없습니다.
css 에 display: none 이 어떤 element 을 감춘다면 jQuery 에서는 이걸 .hide 로 표현합니다.
이런식으로
$('ul').hide(); //ul 야, 넌 숨어있어
그리고 어제는 css 에서 마우스 오버시 display: block 이렇게 해서 숨겨졌던걸 보여지게 했는데,
jQuery 에서는 이 숨겨진 element 를 이런식으로
$('ul').show(); //ul 야, 이제 튀어나와
합니다.
그런데 이걸 부드럽게 보여지게 하려면 .show 대신 .fadeIn, 과 .fadeOut, 혹은 .fadeTo 를 사용할 수 있습니다. (사실 animate 과 opacity 도 이용할 수 있고, 방법은 무궁무진 합니다.)
어제와 같이 html 마크업이 이렇다고 했을때
<ul id="drop">
<li>
공지사항
<ul>
<li>하위메뉴</li>
</ul>
</li>
</ul>
1. 일단 jQuery 를 작성하려면 jQuery 를 불러와야죠. 이렇게.
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
2. 그리고 jQuery 명령문은 이런식이 되겠죠.
$('ul ul').hide(); //숨어있어
$('ul#drop li').hover(function() { //마우스 오버하면
$(this).children('ul').fadeIn(); //부드럽게 튀어나와
}, function() {
$(this).children('ul').fadeOut(); //부드럽게 들어가
});
3. 그런데 이렇게 하면 다큐먼트가 준비되기전/윈도우가 로드되기전 (jQuery 를 어느 위치에 놓느냐에 따라) 먼저 fire 을 해버립니다. 그래서 document ready 나 window load 가 되면 작동해라, 라는 명령문으로 한번 더 감싸야 합니다. 이렇게.
$(window).load(function(){
.
jQuery 명령문
.
});
이러면 마우스 오버시 부드럽게 하위메뉴가 펼쳐지는 메뉴가 만들어 집니다. 끝. 무지 간단하죠?
아, 저 $ 싸인은 뭐냐구요? $ 는 이건 jQuery 다라고 말해 주는 겁니다. 그러니까 $ = jQuery 입니다.
4. jQuery 는 이렇게 생각보다 매우 쉽게 사용할 수 있고, 배우기가 아주 쉽습니다. toggle, animate, fade in 등의 명령어만 넣으면, 아코디언이니, 드랍다운 메뉴니, 기본적인건 뭐든 만들어 쓸수 있습니다. 디자이너라면 당연히 할수 있는 거고, 요구되는 것 입니다. (미국에서는)
이런 간단한 걸 할줄 모르니 퍼블리셔라는 직업군도 한국에는 있는 것 같은데, 사실 제대로 된 디자이너라면 html, css, jQuery 는 손위에 올려놓고 갖고 놀수 있어야 합니다. 어려운게 아니니까요. 퍼블리셔라는 직업군은, 미국이나 다른 나라에는 존재하지 않는 직업군 입니다.
제가 이런말을 한다고, 배려가 없느니, 무례하느니, 왜 몇몇분들이 열폭을 하시는지 저는 이해불가이지만, 서로 의견이 다름을 인지하고, 상식이 통하는 게시판이 되었으면 합니다.
다평정님이 또 "안돼요" 라고 댓글을 올리실까 제가 이제 아주 노이로제가 걸려서, 그냥 ctrl +c, v 하실수 있게, 전문을 작성했습니다. ㅠㅠ
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>드랍다운</title>
<style>
li {
list-style-type:none;
}
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript">
$(window).load(function(){
$(function() {
$('ul ul').hide(); //숨어있어
$('ul#drop li').hover(function() {
$(this).children('ul').fadeIn(); //부드럽게 튀어나와
}, function() {
$(this).children('ul').fadeOut(); //부드럽게 들어가
});
});
});
</script>
</head>
<body>
<ul id="drop">
<li>
공지사항
<ul>
<li>하위메뉴</li>
</ul>
</li>
</ul>
</body>
</html>
/////
*다평정님, 이것만 돌리시면 IE 에서나 크롬에서나 분명히 작동됩니다. 작동이 안되는 경우는, 다평정님께서 집어넣으신 다른 javascript 부분에서의 오류 때문입니다. ㅠㅠ
댓글 1개
13년 전
팁 감사합니다~ㅋㅋㅋㅠㅠ
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 8130 | 9년 전 | 454 | ||
| 8129 |
|
9년 전 | 625 | |
| 8128 | 9년 전 | 491 | ||
| 8127 |
|
9년 전 | 554 | |
| 8126 | 9년 전 | 483 | ||
| 8125 | 9년 전 | 743 | ||
| 8124 |
|
9년 전 | 468 | |
| 8123 | 9년 전 | 456 | ||
| 8122 | 9년 전 | 396 | ||
| 8121 | 9년 전 | 504 | ||
| 8120 | 9년 전 | 440 | ||
| 8119 | 9년 전 | 514 | ||
| 8118 |
|
9년 전 | 596 | |
| 8117 |
|
9년 전 | 375 | |
| 8116 |
PASKRAN
|
9년 전 | 446 | |
| 8115 | 9년 전 | 435 | ||
| 8114 |
kiplayer
|
9년 전 | 574 | |
| 8113 | 9년 전 | 402 | ||
| 8112 |
|
9년 전 | 523 | |
| 8111 | 9년 전 | 373 | ||
| 8110 | 9년 전 | 417 | ||
| 8109 | 9년 전 | 330 | ||
| 8108 |
|
9년 전 | 513 | |
| 8107 |
|
9년 전 | 405 | |
| 8106 |
|
9년 전 | 407 | |
| 8105 | 9년 전 | 447 | ||
| 8104 |
|
9년 전 | 404 | |
| 8103 |
|
9년 전 | 404 | |
| 8102 |
|
9년 전 | 354 | |
| 8101 |
snshero
|
9년 전 | 745 | |
| 8100 | 9년 전 | 811 | ||
| 8099 | 9년 전 | 777 | ||
| 8098 | 9년 전 | 691 | ||
| 8097 | 9년 전 | 481 | ||
| 8096 | 9년 전 | 675 | ||
| 8095 | 9년 전 | 787 | ||
| 8094 | 9년 전 | 471 | ||
| 8093 | 9년 전 | 766 | ||
| 8092 | 9년 전 | 727 | ||
| 8091 | 9년 전 | 1124 | ||
| 8090 | 9년 전 | 731 | ||
| 8089 | 9년 전 | 936 | ||
| 8088 | 9년 전 | 612 | ||
| 8087 | 9년 전 | 715 | ||
| 8086 | 9년 전 | 492 | ||
| 8085 | 9년 전 | 453 | ||
| 8084 | 9년 전 | 589 | ||
| 8083 | 9년 전 | 560 | ||
| 8082 | 9년 전 | 728 | ||
| 8081 | 9년 전 | 441 | ||
| 8080 | 9년 전 | 531 | ||
| 8079 | 9년 전 | 476 | ||
| 8078 | 9년 전 | 417 | ||
| 8077 | 9년 전 | 492 | ||
| 8076 | 9년 전 | 378 | ||
| 8075 | 9년 전 | 395 | ||
| 8074 | 9년 전 | 359 | ||
| 8073 | 9년 전 | 412 | ||
| 8072 | 9년 전 | 399 | ||
| 8071 |
o1o111
|
9년 전 | 848 | |
| 8070 | 9년 전 | 366 | ||
| 8069 | 9년 전 | 299 | ||
| 8068 | 9년 전 | 563 | ||
| 8067 | 9년 전 | 371 | ||
| 8066 | 9년 전 | 397 | ||
| 8065 | 9년 전 | 348 | ||
| 8064 | 9년 전 | 321 | ||
| 8063 | 9년 전 | 286 | ||
| 8062 | 9년 전 | 271 | ||
| 8061 | 9년 전 | 322 | ||
| 8060 | 9년 전 | 342 | ||
| 8059 | 9년 전 | 280 | ||
| 8058 | 9년 전 | 221 | ||
| 8057 | 9년 전 | 341 | ||
| 8056 | 9년 전 | 272 | ||
| 8055 | 9년 전 | 302 | ||
| 8054 | 9년 전 | 326 | ||
| 8053 | 9년 전 | 365 | ||
| 8052 | 9년 전 | 255 | ||
| 8051 | 9년 전 | 295 | ||
| 8050 | 9년 전 | 360 | ||
| 8049 | 9년 전 | 284 | ||
| 8048 | 9년 전 | 400 | ||
| 8047 | 9년 전 | 333 | ||
| 8046 | 9년 전 | 261 | ||
| 8045 | 9년 전 | 231 | ||
| 8044 | 9년 전 | 288 | ||
| 8043 | 9년 전 | 237 | ||
| 8042 | 9년 전 | 266 | ||
| 8041 | 9년 전 | 295 | ||
| 8040 | 9년 전 | 234 | ||
| 8039 | 9년 전 | 292 | ||
| 8038 | 9년 전 | 250 | ||
| 8037 | 9년 전 | 360 | ||
| 8036 | 9년 전 | 448 | ||
| 8035 | 9년 전 | 400 | ||
| 8034 | 9년 전 | 359 | ||
| 8033 | 9년 전 | 315 | ||
| 8032 | 9년 전 | 366 | ||
| 8031 | 9년 전 | 300 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기