it-swarm.dev

فرض متصفح لتنزيل ملفات الصور عند النقر

أحتاج إلى المتصفح لتنزيل ملفات الصور تمامًا كما يفعل أثناء النقر فوق ورقة 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="http://localhost:55298/SaveImage/demo/Sample2.xlsx" target="_blank">Excel</a><br />
                    <a href="http://localhost:55298/SaveImage/demo/abc.jpg" id="abc">Image</a>
                </p>
            </div>
        </form>
    </body>
</html>

كيف ينبغي أن تعمل في حالة تنزيل ورقة Excel (ما تفعله المتصفحات)؟

75
Amit

باستخدام HTML5 ، يمكنك إضافة السمة "تنزيل" إلى روابطك.

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

ستطالب المتصفحات المتوافقة بعد ذلك بتنزيل الصورة بنفس اسم الملف (في هذا المثال image.png).

إذا حددت قيمة لهذه السمة ، فسيصبح ذلك اسم الملف الجديد:

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

UPDATE: اعتبارًا من ربيع عام 2018 ، لم يعد هذا ممكنًا للنسخة المتقاطعة الأصل hrefs . لذلك إذا كنت ترغب في إنشاء <a href="https://i.imgur.com/IskAzqA.jpg" download> في مجال آخر غير imgur.com ، فلن يعمل كما هو مقصود. إعلان إهمال وإزالة عمليات كروم

141
Richard Parnaby-King

لقد نجحت في تشغيل هذا في 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);
78
DrowsySaturn

ليروي وريتشارد بارنابي كينج:

استكمال: اعتبارًا من ربيع عام 2018 ، لم يعد هذا ممكنًا بالنسبة إلى hrefs عبر الأصل. لذلك ، إذا كنت ترغب في الإنشاء على مجال آخر غير imgur.com ، فلن يعمل كما هو مقصود. إعلان إهمال وإزالة عمليات كروم

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();
}
19
iXs
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);     
11
Sadi

تحديث ربيع 2018

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

على الرغم من أن هذا لا يزال مدعومًا ، فقد تم تعطيل هذه الميزة للتنزيل عبر المنشأ اعتبارًا من فبراير 2018 ، مما يعني أن هذا لن يعمل إلا إذا كان الملف موجودًا على نفس اسم المجال.

لقد اكتشفت حلاً لتنزيل صور عبر المجال بعد التحديث الجديد لـ Chrome والذي عطل تنزيل النطاق. يمكنك تعديل هذا إلى وظيفة لتناسب احتياجاتك. قد تكون قادرًا على الحصول على صورة mime-type (jpeg ، png ، gif ، إلخ) مع بعض الأبحاث الإضافية إذا احتجت إليها. قد تكون هناك طريقة لفعل شيء مشابه لهذا مع مقاطع الفيديو أيضًا. أمل أن هذا يساعد شخصاما!

ليروي وريتشارد بارنابي كينج:

استكمال: اعتبارًا من ربيع عام 2018 ، لم يعد هذا ممكنًا بالنسبة إلى hrefs عبر الأصل. لذلك ، إذا كنت ترغب في الإنشاء على مجال آخر غير imgur.com ، فلن يعمل كما هو مقصود. إعلان إهمال وإزالة عمليات كروم

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>
10
Riley Bell

هذا هو الحل العام لمشكلتك. لكن هناك جزءًا مهمًا للغاية يجب أن يتطابق امتداد الملف مع ترميزك. وبالطبع ، يجب أن تكون معلمة المحتوى الخاصة بوظيفة 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>
5
hakobpogh

جرب هذا:

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

يمكنك تحميل هذا الملف مباشرة باستخدام مرساة العلامة دون الكثير من التعليمات البرمجية.
انسخ المقتطف والصقه في محرر النصوص وجربه ...!

<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>
1
vinodh

نهج أكثر حداثة باستخدام Promise and async/انتظار:

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

0
Curse