jquery slick.js中的错误:"未捕获的类型错误:无法读取空""的属性"add"

yrdbyhpb  于 2023-01-04  发布在  jQuery
关注(0)|答案(2)|浏览(329)

我使用光滑的js为图像的滑块视图。
这是我的代码。

<div class="slider_wrap add-remove">
    <%= f.fields_for :images do |image_form| %>
      <%#= render 'images_fields', :f => image_form %>
        <div>
          <%= image_tag image_form.object.picture.url,:class=>"drop_down_link even img_prev" %>
        </div>
        <div class="image_upload_div">
          <div class="image-upload">
            <label>
              <i class="fa fa-cloud-upload">
                <%= image_form.file_field :picture ,:'data-role'=>"none",:onchange=>"readURL(this);" , :accept => 'image/jpeg , image/png' %>
              </i>
            </label>
          </div>
        </div>
    <% end %>
    <%= f.link_to_add "Add a picture", :images ,:id=>"add_pic" ,:class=>"js-add-slide", :style=>"display: none;"%>
</div>

<script>
function silder(){
    slideIndex = 0;
      $('.add-remove').slick({
        slidesToShow: 2,
        slidesToScroll: 2
      });
      $('.js-add-slide').on('click', function() {
        $('.add-remove').slick('slickAdd');
      });

      $('.js-remove-slide').on('click', function() {
        $('.add-remove').slick('slickRemove');
      });
});
function readURL(input) {
  if (input.files && input.files[0]) {
    var reader = new FileReader();
    reader.onload = function (e) {
    $('.img_prev').last()
      .attr('src', e.target.result)
    };

    reader.readAsDataURL(input.files[0]);

    setTimeout(function(){
      $('#add_pic').trigger('click');
      silder();
    }, 100);
  }
}
</script>

现在有了这个代码,我得到了滑块工作,但它不来正确的我得到错误:
未捕获的类型错误:无法读取空值的属性"add"

efzxgjgh

efzxgjgh1#

这是由于两次调用init,它可以正常工作:

$(".slider").not('.slick-initialized').slick()

还有,“silder”看起来像个打字错误。
不幸的是,Internet Explorer uses a different event to tell you when the HTML elements and JS libraries have been loaded.有很多库可以避免100行左右的跨浏览器代码,但是流行的、相对较小的jQuery解决了时间问题,如下所示:

$(function() {
  // Handler for .ready() called. Put the Slick Slider etc. init code here.
})
ecbunoof

ecbunoof2#

对我来说,我也有类似的情况。它发生在我身上,当我使用光滑的内部页面生成器来保存页面内容。所以
光滑初始化
类与该元素一起添加,我们尝试再次调用js。这使我们调用了两次,并且无法为我们工作。因此,如果您将其保存在HTML内容中,请在div中使用slick初始化的类或使用js进行调用。不要同时使用这两种方法。

相关问题