我正在使用位于http://ryrych.github.io/rcarousel/的“rcarousel - 一个连续的jQuery UI轮播”。创建旋转木马后,我希望更改其中一个旋转木马窗格的内容。我可以使用以下脚本轻松更改内容:$('#carousel').find('input.change').click(function(){$(this).parent().parent().find('div.display').html('New content');});
问题是,如果您转到另一个窗格,然后返回,“已更改”窗格将恢复为原始内容。
实例位于http://tapmeister.com/test/ryrych-rcarousel/examples/dynamic.php,脚本包含在下面。
var active=true;
$("#carousel").rcarousel(
{
visible: 1,
step: 1,
width: 780,
height: 240,
speed: 500,
startAtPage: 2,
start: function() {
var carousel=$(this),parent=carousel.parent();
$('#next-slide').click(function(){if(active) {carousel.rcarousel("next");}});
$('#prev-slide').click(function(){if(active) {carousel.rcarousel("prev");}});
for ( var i = 0; i < carousel.rcarousel( "getTotalPages" ); i++ ) {
$("<a />",{href:'#','class':'carousel-bullet off'})
.bind("click", {page: i},
function( event ) {
if(active) {
carousel.rcarousel( "goToPage", event.data.page );
event.preventDefault();
}
}
)
.appendTo( "#carousel-pages" );
}
// mark first page as active
$( "a:eq(0)", "#carousel-pages" )
.removeClass( "off" )
.addClass( "on" )
.css("background-image", "url(images/page-on.png)" );
$("#next-slide, #prev-slide, .carousel-bullet" )
.hover(
function(){
if(active){$( this ).css("opacity", 0.7 );}
},
function(){
if(active){$( this ).css("opacity", 1.0 );}
}
);
},
pageLoaded: function( event, data ) {
$( "a.on", "#carousel-pages" )
.removeClass( "on" )
.css("background-image", "url(images/page-off.png)" );
$( "a", "#carousel-pages" )
.eq( data.page )
.addClass( "on" )
.css("background-image", "url(images/page-on.png)" );
}
}
);
<div id="carousel-container">
<div id="carousel">
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 0</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 1</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 2</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 3</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 4</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
<div class="slide">
<div class="sub-slide">
<img src="images/throbber.gif" class="throbber" alt="Please Wait" />
<div class="display">Display 5</div>
</div>
<div class="buttons">
<input class="change" type="button" value="change">
</div>
</div>
</div>
<a href="#" id="next-slide" class="change-slide"></a>
<a href="#" id="prev-slide" class="change-slide"></a>
<div id="carousel-pages"></div>
</div>
答案 0 :(得分:0)
将以下updatePageDOM()
方法添加到插件
updatePageDOM: function() {
var $root = $(this.element),
data=$root.data("data");
//Note that data.paths[data.pageIndex] and data.pages[data.pageIndex][0] is the same
data.paths[data.pageIndex].html($root.find('div.slide').html());
},