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

작업하다 곤란하면 제일 먼저 찾는 곳이 여기 뿐이네요...
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
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,632
14년 전 조회 2,030
14년 전 조회 1,534
14년 전 조회 2,704
14년 전 조회 1,963
14년 전 조회 1,967
14년 전 조회 1,601
14년 전 조회 2,266
14년 전 조회 3,069
14년 전 조회 1,578
14년 전 조회 1,462
14년 전 조회 1,675
14년 전 조회 4,259
14년 전 조회 1,721
14년 전 조회 2,266
14년 전 조회 2,061
14년 전 조회 1,682
14년 전 조회 8,716
14년 전 조회 2,047
14년 전 조회 2,722
14년 전 조회 1,718
14년 전 조회 2,086
14년 전 조회 1,914
14년 전 조회 2,876
14년 전 조회 4,313
14년 전 조회 2,531
14년 전 조회 4,228
14년 전 조회 2,411
14년 전 조회 4,845
14년 전 조회 2,392
14년 전 조회 1,949
14년 전 조회 2,873
14년 전 조회 3,668
14년 전 조회 2,560
14년 전 조회 2,386
14년 전 조회 4,157
14년 전 조회 2,179
14년 전 조회 1,719
14년 전 조회 2,613
14년 전 조회 1,823
14년 전 조회 6,162
14년 전 조회 1,813
14년 전 조회 2,183
14년 전 조회 1,795
14년 전 조회 1,862
14년 전 조회 1,959
14년 전 조회 2,769
14년 전 조회 2,612
14년 전 조회 2,295
14년 전 조회 2,502
14년 전 조회 4,718
14년 전 조회 1,806
14년 전 조회 2,699
14년 전 조회 2,528
14년 전 조회 1,661
14년 전 조회 1,793
14년 전 조회 1,586
14년 전 조회 9,440
14년 전 조회 1,905
14년 전 조회 2,708
14년 전 조회 2,375
14년 전 조회 1,783
14년 전 조회 1,559
14년 전 조회 4,782
14년 전 조회 1,594
14년 전 조회 1,751
14년 전 조회 2,810
14년 전 조회 2,311
14년 전 조회 2,347
14년 전 조회 2,034
14년 전 조회 2,015
14년 전 조회 1,735
14년 전 조회 2,230
14년 전 조회 1,910
14년 전 조회 2,761
14년 전 조회 2,106
14년 전 조회 3,797
14년 전 조회 1,639
14년 전 조회 3,297
14년 전 조회 3,650
14년 전 조회 5,359
14년 전 조회 2,010
14년 전 조회 2,219
14년 전 조회 2,420
14년 전 조회 2,203
14년 전 조회 2,264
14년 전 조회 3,917
14년 전 조회 2,324
14년 전 조회 2,061
14년 전 조회 2,192
14년 전 조회 2,183
14년 전 조회 1,896
14년 전 조회 2,744
14년 전 조회 3,016
14년 전 조회 2,446
14년 전 조회 2,014
14년 전 조회 1,941
14년 전 조회 1,802
14년 전 조회 2,659
14년 전 조회 3,672