RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 865482
Accepted
Азамат Шарафутдинов
Азамат Шарафутдинов
Asked:2020-08-07 19:41:06 +0000 UTC2020-08-07 19:41:06 +0000 UTC 2020-08-07 19:41:06 +0000 UTC

限制上传文件的数量

  • 772

有一个脚本,由于某种原因,它在这里不起作用。
任务如下:限制上传文件数量为10个。我们选择了11个,只添加10个,删除第11个。添加了 3 个文件 - 只能上传 7 个。

      $(document).ready(function() {
      $(".add_photo-item").on("click", function() {
            $('#js-photo-upload').trigger("click");
        });

  var maxFileSize = 2 * 1024 * 1024; // (байт) Максимальный размер файла (2мб)
    var queue = {};
    
    var imagesList = $('#uploadImagesList');
    var itemPreviewTemplate = imagesList.find('.item').clone();
    imagesList.find('.item').remove();


    $('#js-photo-upload').on('change', function () {
        var files = this.files;      
 
            for (var i = 0; i < files.length; i++) {
                var file = files[i];
                if ( !file.type.match(/image\/(jpeg|jpg|png|gif)/) ) {
                    alert( 'Фотография должна быть в формате jpg, png или gif' );
                    continue;
                }
                if (file.size > maxFileSize) {
                    alert( 'Размер фотографии не должен превышать 2 Мб' );
                    continue;
                }    
                preview(files[i]);
            }
        this.value = '';
    });

    function preview(file) {   
        var reader = new FileReader();
        reader.addEventListener('load', function(event) {
            var img = document.createElement('img');
            var itemPreview = itemPreviewTemplate.clone();
            itemPreview.find('.img-wrap img').attr('src', event.target.result);
            itemPreview.data('id', file.name);
            imagesList.append(itemPreview);
            queue[file.name] = file;

        });
        reader.readAsDataURL(file);     
    }


});
#js-photo-upload {
           display: none;
       }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

    <input type="file" name="add-photo" multiple id="js-photo-upload">
    <div class="add_photo-content">
    <ul id="uploadImagesList">
    <li class="item"><span class="img-wrap"><img src="" alt=""></span><span class="delete-link" title="Удалить">Удалить</span></li>
    </ul>
    <div class="add_photo-item">+</div>
    </div>

javascript
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    UModeL
    2020-08-08T03:26:27Z2020-08-08T03:26:27Z

    更改和添加的行和函数提供了上面的注释(没有调试和可见性,新代码不到三倍):

    $(document).ready(function() {
      $('.add_photo-item').on('click', function() {
        $('#js-photo-upload').trigger('click');
      });
    
      var maxFileSize = 2 * 1024 * 1024; // (байт) Максимальный размер файла (2мб)
      var queue = {};
    
      var imagesList = $('#uploadImagesList');
      // 'detach' подобно 'clone + remove'
      var itemPreviewTemplate = imagesList.find('.item').detach();
    
      // Вычисление лимита
      function limitUpload() {
        return 10 - imagesList.children().length;
      }
      // Отображение лимита
      function limitDisplay() {
        let sTxt;
        switch (limitUpload()) {
          case 10:
            sTxt = '+ (можно добавить ' + limitUpload() + ' изображений)';
            break;
          case 0:
            sTxt = 'Нельзя больше добавить - достигнут лимит';
            break;
          default:
            sTxt = '+ (можно добавить ещё ' + limitUpload() + ')';
        }
        $('.add_photo-item').html(sTxt);
      }
    
      $('#js-photo-upload').on('change', function() {
        var files = this.files;
        // Перебор файлов до лимита
        for (var i = 0; i < limitUpload(); i++) {
    
          var file = files[i];
          if (!file.type.match(/image\/(jpeg|jpg|png|gif)/)) {
            alert('Фотография должна быть в формате jpg, png или gif');
            continue;
          }
          if (file.size > maxFileSize) {
            alert('Размер фотографии не должен превышать 2 Мб');
            continue;
          }
          preview(files[i]);
        }
        this.value = '';
      });
    
      function preview(file) {
        var reader = new FileReader();
        reader.addEventListener('load', function(event) {
          var img = document.createElement('img');
          var itemPreview = itemPreviewTemplate.clone();
          itemPreview.find('.img-wrap img').attr('src', event.target.result);
          itemPreview.data('id', file.name);
          imagesList.append(itemPreview);
          // Обработчик удаления
          itemPreview.on('click', function() {
            delete queue[file.name];
            $(this).remove();
            limitDisplay();
          });
    
          queue[file.name] = file;
          // Отображение лимита при добавлении
          limitDisplay();
        });
        reader.readAsDataURL(file);
      }
      // Отображение лимита при запуске
      limitDisplay();
    });
    #js-photo-upload {
      display: none;
    }
    
    /* Для отладки */
    .item img {
      width: 24px;
      height: 18px;
    }
    .add_photo-item {
      border: 1px red solid;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    
    <input type="file" name="add-photo" multiple id="js-photo-upload">
    <div class="add_photo-content">
      <ul id="uploadImagesList">
        <li class="item"><span class="img-wrap"><img src="" alt=""></span><span class="delete-link" title="Удалить">Удалить</span></li>
      </ul>
      <div class="add_photo-item">+</div>
    </div>

    • 4

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5