Vấn đề là dọc theo dòng của những gì @Francesco Frassinelli chỉ ra trong các bình luận, cụ thể là khi băng chuyền đang sử dụng hiệu ứng chuyển tiếp CSS3 (về cơ bản bất kỳ trình duyệt nhưng IE), nếu một băng chuyền được ẩn khi một quá trình chuyển đổi kết thúc, sự kiện $.support.transition.end
sẽ không bao giờ được kích hoạt. Điều này sẽ khiến băng chuyền bị tạm ngưng trong trạng thái trượt và ngắn mạch tất cả chức năng của nó.
Trong Issue #1887@fat ném vào đề nghị của ông để ngăn ngừa nó khỏi bị mắc kẹt ở nơi đầu tiên:
"Bạn sẽ cần phải tạm dừng trình chiếu và tiếp tục nó trước/sau chuyển đổi qua lại màn hình . "
Tôi cũng đề nghị một cách giải quyết khi sử dụng một băng chuyền trong một phương thức trong Issue #3351, mà có thể dễ dàng được điều chỉnh đối với trường hợp sử dụng của bạn:
$('a[href="#responses-1"]').on('shown', function() {
var $carousel = $('.carousel');
if ($carousel.data('carousel') && $carousel.data('carousel').sliding) {
$carousel.find('.active').trigger($.support.transition.end);
}
});
này về cơ bản chỉ mở băng chuyền khi nó trở nên rõ ràng nếu nó sẽ bị đình chỉ.
Vì hành vi xấu này xảy ra trên nhiều trường hợp khác nhau, tôi đã đưa ra đề xuất trong Issue #3351 về tính khả thi của giải pháp vĩnh viễn tiềm năng có thể được tích hợp trực tiếp vào mã plugin bootstrap-carousel.js. Nếu bất cứ ai nghĩ rằng đó là một ý tưởng hay, hoặc có ý tưởng khác về cách thực hiện nó, vấn đề đó vẫn còn mở, vì vậy phản hồi được hoan nghênh.
Related: [issue 1887] (https://github.com/twitter/bootstrap/issues/1887), [issue 2196] (https://github.com/twitter/bootstrap/issues/2196), [ câu hỏi: cách kết hợp các tab và băng chuyền] (http://stackoverflow.com/questions/12327796/how-to-combine-tabs-and-carousel-in- twitter-bootstrap/12332045) –