alt-rock alt-rock - 1 year ago 69
CSS Question

Call jquery event handler out of scope

I am trying to call a function to add class

to a link outside the scope of the carousel when an image inside has the class
. The active class iterates over each
, toggling on and off every
3 sec

How can i add the class when the item is active?


var test = $('.active');

function linkHover() {
if ($('').length != 0) {

.hover {
color: red

<script src=""></script>
<div class="carousel">
<div id="slide1" class="item">
<img src="img1.jpg">
<div id="slide2" class="item">
<img src="img2.jpg">
<div id="slide3" class="item active">
<img src="img3.jpg">
<div class="nav-links">
<a id="link1">Link</a>
<a id="link2">Link</a>
<a id="link3">Link</a>

Answer Source

Since you are using owl-carousel, you should not find a way to call something out of scope, you should look for ways to capture events and then add your code on those events.

You can check owl carousel - event docs for events and their signature.

In your case, you need change event:

owl.on('changed.owl.carousel', function(event) {

Now as per your fiddle, I have added an extra link as you have 5 sliding divs and 4 links.

You can refer following JSFiddle for working demo.

I'll try to find a better and more generic way to get current element's index. You can use $('').removeClass('hover').next().addClass('hover'), but this will need more refining.

Let me know if you have any queries.

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download