の子が見つからない場合は、クラス名が.slideshow-dots
のdivから子を取得できません。ここでの子供を持つdiv要素です:何らかの理由で、要素
<div class="slideshow-dots">
<span class="dot"></span>
<span class="dot"></span>
<span class="dot"></span>
<span class="dot"></span>
</div>
が、これは誤りである:以下
が私のコードですが、私はまた、公共メソッドUncaught TypeError: Cannot read property 'className' of undefined
showSlides
を呼び出すことができないんです。
(function($) {
$.fn.MarvSimpleGallery = function(options) {
var instance = this;
instance.index = 1;
var settings = $.extend({
// These are the defaults.
arrows: true,
dots: true,
numbers: true
}, options);
var init = function() {
instance.dotCont = instance.find('.slideshow-dots')[0];
instance.slides = instance.find('.mySlides');
// Assign event listeners
instance.find('.prev').click(function() { instance.showSlides(instance.index += -1); });
instance.find('.next').click(function() { instance.showSlides(instance.index += 1); });
// Initiate dot controls
$.each(instance.slides, function(index, data) {
var dot = $('<span></span>');
dot.addClass('dot');
dot.click(function() { instance.showSlides(instance.index = (index + 1)); });
$(instance.dotCont).append(dot);
});
// Show initial slide
}();
instance.showSlides = function(n) {
console.log('Slide: ' + n);
if (n > (instance.slides).length) instance.index = 1;
if (n < 1) instance.index = (instance.slides).length;
var slideCount = (instance.slides).length;
$.each(instance.slides, function(index, data) {
data.style.display = "none";
$(data).prepend($('<div></div>').addClass('numbertext').append((index + 1) + '/' + slideCount));
});
instance.slides[instance.index-1].style.display = "block";
$(instance.dotCont).find('dots')[instance.index-1].className += " active";
};
}
}(jQuery));
でなければならない、 'instance.index-1 'は有効なキーではありませんあなたのコードの最後の行のコレクションのために。実例を共有する(jsfiddle、stacksnippets、codepen ....) –
私たちを助けて、どのラインがエラーを投げているかのヒントを教えてください。 –
別の質問:jQueryとvanilla JSを混ぜる理由 –