자바스크립트 고수님께 (+ - 버튼이미지 스왑 관련)

작업하다 곤란하면 제일 먼저 찾는 곳이 여기 뿐이네요...
JS / JQuery 관련 질문인데 도움을 부탁드립니다. ㅠㅠ

Toggle 관련 Jquery를 사용해서 페이지 제작중입니다.

http://jandspace.com/kaplan/toggle_test.html

위 링크에 보시면 + 버튼이 3개 있고 그 중 제일 위에 링크를 누르면
DIV가 슬라이딩되면서 내려오고 + 버튼은 - 버튼으로 바뀝니다.

문제는 똑같은 스크립트를 아래 2개의 버튼에 적용하면 작동을 하지 않습니다.

링크 갯수는 딱 3개만 둘 것은 아니고 여러 개가 추가될 수 있어서요
onclick 이벤트를 입력한 곳에 해당 라인의 + - 버튼에만 이벤트가 발생했으면 하는데요...
(아마도 변수가 필요한 것이 아닌지... 아니면 심플하게 만들 수 있을지...)

JS / JQuery 고수님들 한번 보시구서 도움을 주셨으면 합니다. (초보라서... 잘 알려주시면...^^;;)
미리 감사드립니닷!! 
|

댓글 2개

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<link type="text/css" rel="stylesheet" href="kaplan.css" media="screen" />

<style type="text/css">
.exp_box {
background-color: #FFFFFF;
padding: 10px;
margin: 4px 10px 16px 0;
border: 1px solid #c4c4c4;
text-align: justify;
line-height: 18px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
-moz-box-shadow: inset 0 0 30px #DDDDDD;
-webkit-box-shadow: inset 0 0 30px #DDDDDD;
box-shadow: inset 0 0 30px #DDDDDD;
overflow: hidden;
display: none;
font-family: Tahoma, Geneva, sans-serif;
}
.exp_box p {
margin: 0;
padding: 0;
}
.close_box {
text-align: right;
display: block;
padding: 0 0 0 0;
}
.exp_box h3 {
margin: 0 0 -16px 0;
padding: 0;
color: #415bf5;
font-size: 17px;
}
#box_button {
vertical-align: -3px;
margin: 0 0 0 6px;
}
.show_hide {
cursor: pointer;
}
</style>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
(function ($) {
$(document).ready(function(){
$('.show_hide').showHide({
speed: 400, // speed you want the toggle to happen
easing: '', // the animation effect you want. Remove this line if you dont want an effect and if you haven't included jQuery UI
changeText: 0, // if you dont want the button text to change, set this to 0
showText: 'View',// the button text to show when a div is closed
hideText: 'Close' // the button text to show when a div is open

});

});

$.fn.showHide = function (options) {

//default vars for the plugin
var defaults = {
speed: 1000,
easing: '',
changeText: 0,
showText: 'Show',
hideText: 'Hide'

};
var options = $.extend(defaults, options);
var flag=0;

$(this).click(function () {

$('.toggleDiv').slideUp(options.speed, options.easing);
// this var stores which button you've clicked
var toggleClick = $(this);
// this reads the rel attribute of the button to determine which div id to toggle
var toggleDiv = $(this).attr('rel');
// here we toggle show/hide the correct div at the right speed and using which easing effect
$(toggleDiv).slideToggle(options.speed, options.easing, function() {
// this only fires once the animation is completed
if(options.changeText==1){
$(toggleDiv).is(":visible") ? toggleClick.text(options.hideText) : toggleClick.text(options.showText);
}
});

var img = $(this).find('img');
var src = img.attr('src');

//image is open
if(src == 'box_open.gif') {
img.attr('src','box_close.gif');
}
//image is close
if(src == 'box_close.gif') {
img.attr('src','box_open.gif');
}

return false;

});

};
})(jQuery);
</script>
</head>
<body>
<div style="width: 600px; font-size: 12px">
<h2><strong>Title</strong></h2>
<ul>
<li>

<a class="show_hide" rel="#slidingDiv1">Intensive English Courses<img name="img1" src="box_open.gif" alt="Box Open" id="box_button" /></a>
<div id="slidingDiv1" class="exp_box">
<p>
<h3>Intensive English Courses</h3><br />
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus imperdiet nibh a risus blandit ut fringilla ante adipiscing. Donec non ligula elit. Nulla suscipit dapibus vulputate. Cras purus dolor, scelerisque sed congue sed, aliquet pellentesque nisi. Suspendisse sed odio at mi iaculis elementum vitae a tellus. Nulla ac adipiscing enim. Pellentesque vulputate purus et nisl rhoncus volutpat. Proin dapibus, tortor nec dignissim lobortis, tortor nulla facilisis sapien, vitae rhoncus lorem lorem nec leo. Ut a tellus euismod neque feugiat ultricies fringilla id nisi. Integer eget justo ipsum. Pellentesque metus ipsum, egestas at molestie consequat, semper eget mi. Integer non ante in sem iaculis pretium. Suspendisse nec massa eget leo fringilla iaculis in a nulla. Duis at lobortis odio. Quisque in nunc velit. Sed pulvinar sem non felis dapibus dictum.
</p>
</div>
</li>
<li>Intensive English Academic Year and Semester</a></li>
<li>
<a class="show_hide" rel="#slidingDiv2">OPUS Paid work and study<img src="box_open.gif" alt="Box Open" id="box_button" /></a>
<div id="slidingDiv2" class="exp_box">
<p>
<h3>OPUS Paid work and study</h3><br />
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus imperdiet nibh a risus blandit ut fringilla ante adipiscing. Donec non ligula elit. Nulla suscipit dapibus vulputate. Cras purus dolor, scelerisque sed congue sed, aliquet pellentesque nisi. Suspendisse sed odio at mi iaculis elementum vitae a tellus. Nulla ac adipiscing enim. Pellentesque vulputate purus et nisl rhoncus volutpat. Proin dapibus, tortor nec dignissim lobortis, tortor nulla facilisis sapien, vitae rhoncus lorem lorem nec leo. Ut a tellus euismod neque feugiat ultricies fringilla id nisi. Integer eget justo ipsum. Pellentesque metus ipsum, egestas at molestie consequat, semper eget mi. Integer non ante in sem iaculis pretium. Suspendisse nec massa eget leo fringilla iaculis in a nulla. Duis at lobortis odio. Quisque in nunc velit. Sed pulvinar sem non felis dapibus dictum.
</p>
</div>
</li>
<li>
<a class="show_hide" rel="#slidingDiv3">Internship placement service<img src="box_open.gif" alt="Box Open" id="box_button" /></a>
<div id="slidingDiv3" class="exp_box">
<p>
<h3>Internship placement service</h3><br />
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus imperdiet nibh a risus blandit ut fringilla ante adipiscing. Donec non ligula elit. Nulla suscipit dapibus vulputate. Cras purus dolor, scelerisque sed congue sed, aliquet pellentesque nisi. Suspendisse sed odio at mi iaculis elementum vitae a tellus. Nulla ac adipiscing enim. Pellentesque vulputate purus et nisl rhoncus volutpat. Proin dapibus, tortor nec dignissim lobortis, tortor nulla facilisis sapien, vitae rhoncus lorem lorem nec leo. Ut a tellus euismod neque feugiat ultricies fringilla id nisi. Integer eget justo ipsum. Pellentesque metus ipsum, egestas at molestie consequat, semper eget mi. Integer non ante in sem iaculis pretium. Suspendisse nec massa eget leo fringilla iaculis in a nulla. Duis at lobortis odio. Quisque in nunc velit. Sed pulvinar sem non felis dapibus dictum.
</p>
</div>
</li>
</ul>
</div>
</body>
</body>
</html>
저를 살리셨습니다.
무한 감사를 드립니다. (_ _) 정말 잘되네요...(^_^)=b
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
13년 전 조회 761
13년 전 조회 1,119
13년 전 조회 660
13년 전 조회 1,782
13년 전 조회 1,053
13년 전 조회 1,078
13년 전 조회 701
13년 전 조회 1,336
13년 전 조회 2,136
13년 전 조회 670
13년 전 조회 563
13년 전 조회 748
13년 전 조회 3,323
13년 전 조회 805
13년 전 조회 1,349
13년 전 조회 1,134
13년 전 조회 777
13년 전 조회 7,777
13년 전 조회 1,162
13년 전 조회 1,804
13년 전 조회 799
13년 전 조회 1,141
13년 전 조회 978
13년 전 조회 1,943
13년 전 조회 3,358
13년 전 조회 1,586
13년 전 조회 3,296
13년 전 조회 1,452
13년 전 조회 3,899
13년 전 조회 1,460
13년 전 조회 959
13년 전 조회 1,924
13년 전 조회 2,706
13년 전 조회 1,617
13년 전 조회 1,429
13년 전 조회 3,188
13년 전 조회 1,218
13년 전 조회 774
13년 전 조회 1,663
13년 전 조회 895
13년 전 조회 5,217
13년 전 조회 872
13년 전 조회 1,262
13년 전 조회 865
13년 전 조회 881
13년 전 조회 1,006
13년 전 조회 1,802
13년 전 조회 1,618
13년 전 조회 1,342
13년 전 조회 1,551
13년 전 조회 3,700
13년 전 조회 809
13년 전 조회 1,700
13년 전 조회 1,518
13년 전 조회 672
13년 전 조회 798
13년 전 조회 674
13년 전 조회 8,406
13년 전 조회 893
13년 전 조회 1,691
13년 전 조회 1,366
13년 전 조회 794
13년 전 조회 541
13년 전 조회 3,766
13년 전 조회 587
13년 전 조회 742
13년 전 조회 1,799
13년 전 조회 1,299
13년 전 조회 1,342
13년 전 조회 1,041
13년 전 조회 994
13년 전 조회 743
13년 전 조회 1,294
13년 전 조회 898
13년 전 조회 1,720
13년 전 조회 1,066
13년 전 조회 2,738
13년 전 조회 610
13년 전 조회 2,273
13년 전 조회 2,667
13년 전 조회 4,427
13년 전 조회 998
13년 전 조회 1,213
13년 전 조회 1,397
13년 전 조회 1,212
13년 전 조회 1,214
13년 전 조회 2,883
13년 전 조회 1,297
13년 전 조회 1,051
13년 전 조회 1,183
13년 전 조회 1,175
13년 전 조회 858
13년 전 조회 1,729
13년 전 조회 2,124
13년 전 조회 1,407
13년 전 조회 1,000
13년 전 조회 981
13년 전 조회 878
13년 전 조회 1,606
13년 전 조회 2,642
🐛 버그신고