Подтвердить что ты не робот

Заставить браузер загружать файлы изображений по клику

Мне нужно, чтобы браузер загружал файлы изображений так же, как и при нажатии на лист Excel.

Есть ли способ сделать это, используя только клиентское программирование?

<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <title></title>
        <script type="text/javascript" src="Scripts/jquery-1.10.2.js">
        $(document).ready(function () {
            $("*").click(function () {
                $("p").hide();
            });
        });
        </script>
    </head>

    <script type="text/javascript">
        document.onclick = function (e) {
            e = e || window.event;
            var element = e.target || e.srcElement;
            if (element.innerHTML == "Image") {
                //someFunction(element.href);
                var name = element.nameProp;
                var address = element.href;
                saveImageAs1(element.nameProp, element.href);
                return false; // Prevent default action and stop event propagation
            }
            else
                return true;
        };

        function saveImageAs1(name, adress) {
            if (confirm('you wanna save this image?')) {
                window.win = open(adress);
                //response.redirect("~/testpage.html");
                setTimeout('win.document.execCommand("SaveAs")', 100);
                setTimeout('win.close()', 500);
            }
        }
    </script>

    <body>
        <form id="form1" runat="server">
            <div>
                <p>
                    <a href="#" onclick="location.href='http://localhost:55298/SaveImage/demo/Sample2.xlsx'; return false;" target="_blank">Excel</a><br />
                    <a href="#" onclick="location.href='http://localhost:55298/SaveImage/demo/abc.jpg'; return false;" id="abc">Image</a>
                </p>
            </div>
        </form>
    </body>
</html>

Как он должен работать в случае загрузки листа Excel (что делают браузеры)?

4b9b3361

Ответ 1

Используя HTML5, вы можете добавить атрибут "скачать" в свои ссылки.

<a href="/path/to/image.png" download>

Соответствующие браузеры затем запросят загрузить изображение с тем же именем (в этом примере image.png).

Если вы укажете значение для этого атрибута, это станет новым именем файла:

<a href="/path/to/image.png" download="AwesomeImage.png">

ОБНОВЛЕНИЕ: По состоянию на весну 2018 года это невозможно для перекрестного происхождения href s. Поэтому, если вы хотите создать <a href="https://i.imgur.com/IskAzqA.jpg" download> в домене, отличном от imgur.com, он не будет работать должным образом. Объявление об отказе от Chrome и удаления

Ответ 2

Мне удалось получить эту работу в Chrome и Firefox, добавив ссылку на документ.

var link = document.createElement('a');
link.href = 'images.jpg';
link.download = 'Download.jpg';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);

Ответ 3

Лерой и Ричард Парнаби-Кинг:

ОБНОВЛЕНИЕ: По состоянию на весну 2018 года это больше невозможно для перекрестного происхождения hrefs. Поэтому, если вы хотите создать в домене, отличном от imgur.com, он не будет работать должным образом. Объявление об отказе от Chrome и удаления

function forceDownload(url, fileName){
    var xhr = new XMLHttpRequest();
    xhr.open("GET", url, true);
    xhr.responseType = "blob";
    xhr.onload = function(){
        var urlCreator = window.URL || window.webkitURL;
        var imageUrl = urlCreator.createObjectURL(this.response);
        var tag = document.createElement('a');
        tag.href = imageUrl;
        tag.download = fileName;
        document.body.appendChild(tag);
        tag.click();
        document.body.removeChild(tag);
    }
    xhr.send();
}

Ответ 4

var pom = document.createElement('a');
pom.setAttribute('href', 'data:application/octet-stream,' + encodeURIComponent(text));
pom.setAttribute('download', filename);
pom.style.display = 'none';
document.body.appendChild(pom);
pom.click();
document.body.removeChild(pom);     

Ответ 5

Обновление весны 2018

<a href="/path/to/image.jpg" download="FileName.jpg">

Хотя это все еще поддерживается, по состоянию на февраль 2018 года Chrome отключил эту функцию для загрузки из разных источников, что означает, что она будет работать, только если файл находится на том же доменном имени.

Я нашел обходной путь для загрузки междоменных изображений после нового обновления Chrome, которое отключило междоменную загрузку. Вы можете изменить это в функцию, чтобы удовлетворить ваши потребности. Вы могли бы получить изображение MIME-типа (JPEG, PNG, GIF и т.д.) С некоторыми дополнительными исследованиями, если вам нужно. Там может быть способ сделать что-то подобное с видео, а также. Надеюсь, это поможет кому-то!

Лирой и Ричард Парнаби-Кинг:

ОБНОВЛЕНИЕ: С весны 2018 года это больше невозможно для перекрестных ссылок. Поэтому, если вы хотите создать домен, отличный от imgur.com, он не будет работать так, как задумано. Объявление об устаревании и удалении Chrome

var image = new Image();
image.crossOrigin = "anonymous";
image.src = "https://is3-ssl.mzstatic.com/image/thumb/Music62/v4/4b/f6/a2/4bf6a267-5a59-be4f-6947-d803849c6a7d/source/200x200bb.jpg";
// get file name - you might need to modify this if your image url doesn't contain a file extension otherwise you can set the file name manually
var fileName = image.src.split(/(\\|\/)/g).pop();
image.onload = function () {
    var canvas = document.createElement('canvas');
    canvas.width = this.naturalWidth; // or 'width' if you want a special/scaled size
    canvas.height = this.naturalHeight; // or 'height' if you want a special/scaled size
    canvas.getContext('2d').drawImage(this, 0, 0);
    var blob;
    // ... get as Data URI
    if (image.src.indexOf(".jpg") > -1) {
    blob = canvas.toDataURL("image/jpeg");
    } else if (image.src.indexOf(".png") > -1) {
    blob = canvas.toDataURL("image/png");
    } else if (image.src.indexOf(".gif") > -1) {
    blob = canvas.toDataURL("image/gif");
    } else {
    blob = canvas.toDataURL("image/png");
    }
    $("body").html("<b>Click image to download.</b><br><a download='" + fileName + "' href='" + blob + "'><img src='" + blob + "'/></a>");
};
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

Ответ 6

Это общее решение вашей проблемы. Но есть одна очень важная часть, что расширение файла должно соответствовать вашей кодировке. И, конечно, этот параметр содержимого функции downlowadImage должен быть закодированной в base64 строкой вашего изображения.

const clearUrl = url => url.replace(/^data:image\/\w+;base64,/, '');

const downloadImage = (name, content, type) => {
  var link = document.createElement('a');
  link.style = 'position: fixed; left -10000px;';
  link.href = `data:application/octet-stream;base64,${encodeURIComponent(content)}`;
  link.download = /\.\w+/.test(name) ? name : `${name}.${type}`;

  document.body.appendChild(link);
  link.click();
  document.body.removeChild(link);
}

['png', 'jpg', 'gif'].forEach(type => {
  var download = document.querySelector(`#${type}`);
  download.addEventListener('click', function() {
    var img = document.querySelector('#img');

    downloadImage('myImage', clearUrl(img.src), type);
  });
});
a gif image: <image id="img" src="" />


<button id="png">Download PNG</button>
<button id="jpg">Download JPG</button>
<button id="gif">Download GIF</button>

Ответ 7

Попробуйте следующее:

<a class="button" href="http://www.glamquotes.com/wp-content/uploads/2011/11/smile.jpg" download="smile.jpg">Download image</a>

Ответ 8

Вы можете напрямую загрузить этот файл, используя тег привязки без особого кода.
Скопируйте фрагмент и вставьте его в текстовый редактор и попробуйте...!

<html>
<head>
</head>
<body>
   <div>
     <img src="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg" width="200" height="200">
      <a href="#" download="https://upload.wikimedia.org/wikipedia/commons/1/1f/SMirC-thumbsup.svg"> Download Image </a>
   </div>
</body>
</html>

Ответ 9

Более современный подход с использованием Promise и async/await:

toDataURL(url) {
    return fetch(url).then((response) => {
            return response.blob();
        }).then(blob => {
            return URL.createObjectURL(blob);
        });
}

затем

async download() {
        const a = document.createElement("a");
        a.href = await toDataURL("https://cdn1.iconfinder.com/data/icons/ninja-things-1/1772/ninja-simple-512.png");
        a.download = "myImage.png";
        document.body.appendChild(a);
        a.click();
        document.body.removeChild(a);
}

Найти документацию можно здесь: https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch

Ответ 10

Как насчет использования функции .click() и тега?

(Сжатая версия)

<a id="downloadtag" href="examplefolder/testfile.txt" hidden download></a>

<button onclick="document.getElementById('downloadtag').click()">Download</button>

Ответ 11

<html>
<head>
<script type="text/javascript">
function prepHref(linkElement) {
    var myDiv = document.getElementById('Div_contain_image');
    var myImage = myDiv.children[0];
    linkElement.href = myImage.src;
}
</script>
</head>
<body>
<div id="Div_contain_image"><img src="YourImage.jpg" alt='MyImage'></div>
<a href="#" onclick="prepHref(this)" download>Click here to download image</a>
</body>
</html>

Ответ 12

Я обнаружил, что

<a href="link/to/My_Image_File.jpeg" download>Download Image File</a>

не работал у меня. Я не уверен, почему.

Я обнаружил, что вы можете включить параметр ?download=true в конце вашей ссылки, чтобы принудительно загрузить. Я думаю, что я заметил, что этот метод используется Google Диском.

В вашей ссылке включите ?download=true в конце вашего href.

Вы также можете использовать эту технику для одновременного установки имени файла.

В вашей ссылке включите ?download=true&filename=My_Image_File.jpeg в конце вашего href.

Ответ 13

Вам не нужно писать js для этого, просто используйте:

<a href="path_to/image.jpg" alt="something">Download image</a>

И сам браузер автоматически загрузит изображение.

Если по какой-то причине он не работает, добавьте атрибут загрузки. С помощью этого атрибута вы можете установить имя для загружаемого файла:

<a href="path_to/image.jpg" download="myImage">Download image</a>