douxianliu6756 2015-07-04 10:24
浏览 90
已采纳

如何使用PHP单击(全部下载)下载所有图像

If I click that Download All I need to download all that image to my local system

<div>
  <img src='image1.jpg'/>
  <img src='image2.jpg'/>
  <img src='image3.jpg'/>
  <button> Download All </button>
</div>

Give me some solution for this

  • 写回答

3条回答 默认 最新

  • dsfsad089111 2015-07-04 11:23
    关注

    If you want to download without zipped them, you can use a javascript function like this to download one to one:

    function downloadWithName(uri, name) {
        function eventFire(el, etype){
            if (el.fireEvent) {
                (el.fireEvent('on' + etype));
            } else {
                var evObj = document.createEvent('MouseEvent');
                evObj.initMouseEvent(etype, true, false, 
                     window, 0,
                     0, 0, 0, 0,
                     false, false, false, false,
                     0, null);
                el.dispatchEvent(evObj);
            }
        }
    
        var link = document.createElement("a");
        link.download = name;
        link.href = uri;
        eventFire(link, "click");
    }
    

    But, you need to make some changes in your code in order to allow to download all images with a single click. In your case, this code will run ;)

    <div id="allImages">
      <img src='image1.jpg'/>
      <img src='image2.jpg'/>
      <img src='image3.jpg'/>
      <button onclick="donwloadAll()"> Download All </button>
    </div>
    
    <script>
    function donwloadAll(){
        var div = document.getElementById("allImages");
        console.log(div);
        var images = div.getElementsByTagName("img");
        console.log(images)
    
        for(i=0; i<images.length ; i++){
            console.log(images[i]);
            downloadWithName(images[i].src,images[i].src);
        }
    }
    
    function downloadWithName(uri, name) {
        function eventFire(el, etype){
            if (el.fireEvent) {
                (el.fireEvent('on' + etype));
            } else {
                var evObj = document.createEvent('MouseEvent');
                evObj.initMouseEvent(etype, true, false, 
                     window, 0,
                     0, 0, 0, 0,
                     false, false, false, false,
                     0, null);
                el.dispatchEvent(evObj);
            }
        }
    
        var link = document.createElement("a");
        link.download = name;
        link.href = uri;
        eventFire(link, "click");
    }
    </script>
    

    As you can imagine, you can add more <img> inside <div id="allImages"> and user will download all together.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?