slider - Isolating jQuery to only contained elements -
I'm looking for a while, and I'm new to zoom and javascript to know that I'm wrong Where am i Any help will be greatly appreciated. I have the script below, which works very well for an element, how can I modify it to work with many elements? If I have many elements on the page then the slider will scroll everything, not just the elements of a container. I know that I can technically create new variables and new class names for each method, but it is messy and I know that there must be a smart way.
& lt; Script type = "text / javascript" charset = "UTF-8" & gt; Window.onload = function () {var Container = $ ('div.sliderGallery'); Var al = $ ('ul', container); Var itemwind = ul.innerWidth () - container.outerWidth (); $ ('Slider', container). Slider ({Min: 0, Max: Items Wideth, Handle: '.', 'Stop: Function (Event, UI) {ul.animate ({' left ': ui.value * -1}, 500);}, Slide: Function (Event, UI) {ul.css ('left', ui.value * -1);}}); }; & Lt; / Script & gt;
And here is html.
& lt; Div class = "sliderGallery" & gt; & Lt; Ul id = "audio-download" & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; / Ul & gt; & Lt; Div class = "slider" & gt; & Lt; Div class = "handle" & gt; & Lt; / Div & gt; & Lt; / Div & gt; & Lt; / Div & gt; & Lt; Div class = "slider gallery" & gt; & Lt; Ul id = "audio-download" & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; Li & gt; & Lt; A href = "#" & gt; Audio title & lt; / A & gt; & Lt; / Li & gt; & Lt; / Ul & gt; & Lt; Div class = "slider" & gt; & Lt; Div class = "handle" & gt; & Lt; / Div & gt; & Lt; / Div & gt; & Lt; / Div & gt;
Update Also saw that You are using window.onload
. In JQuery, you get a $ (document) .ready ()
or its nickname $ (function ())
.
should use each ()
to run through the elements of Slider Gallery
: / P>
$ (function () {// place your window.Open function wrapper $ ('div.sliderGallery'). Each (function () {var ul = $ ('ul', this ); Var itemsWidth = ul.innerWidth () - $ (this) .outerwidth (); $ ('. Slider', this). Slider ({Minimum: 0, Max: items Wideth, Handle: '.dilled', stop : Function (event, UI) {ul.animate ({'left': ui.value * -1}, 500);}, slide: function (event, u E) {ul.css ('left', ui.value * -1);}})}}}}}
each
callback function, this
= in the current dome node. If you need a jQuery object in that context, then use $ (this)
.
Comments
Post a Comment