কিভাবে ফাইল শেয়ার করবেন

প্যালেন্স লিয়াও
Palances Liao

আধুনিক উপায়

ওয়েব শেয়ার API এর share() পদ্ধতি ব্যবহার করে

ফাইল শেয়ার করতে, navigator.share() কল করুন। মনে রাখবেন যে আপনার সর্বদা পরীক্ষা করা উচিত যে ফাইলগুলি navigator.canShare() এর সাথে শেয়ার করা যায় কিনা এবং share() পদ্ধতিতে কল করার আগে নিশ্চিত করুন যে আপনার সাইট HTTPS ব্যবহার করছে।

// Assume `blob` is a PNG image file.
const data = {
  files: [
    new File([blob], 'image.png', {
      type: blob.type,
    }),
  ],
  title: 'My title',
  text: 'My text',
};
if (navigator.canShare(data)) {
  await navigator.share(data);
}

ব্রাউজার সমর্থন

  • ৮৯
  • 93
  • 12.1

উৎস

ক্লাসিক উপায়

ওয়েব শেয়ার API সমর্থিত না হলে ব্যবহারকারীকে অফার করার পরবর্তী সর্বোত্তম জিনিসটি হল ব্যবহারকারীকে ফাইল ডাউনলোড করতে দেওয়া, যাতে তারা ম্যানুয়ালি এটি শেয়ার করতে পারে, উদাহরণস্বরূপ, ইমেলের মাধ্যমে বা মেসেঞ্জার বা অনলাইন সামাজিক নেটওয়ার্ক অ্যাপের মাধ্যমে।

ব্রাউজার সমর্থন

  • 15
  • 13
  • 20
  • 10.1

উৎস

প্রগতিশীল বর্ধিতকরণ

নীচের পদ্ধতিটি ওয়েব শেয়ার API ব্যবহার করে যখন ব্রাউজার এটি সমর্থন করে এবং যখন সমর্থিত ফাইল প্রকারের উপর ভিত্তি করে ডেটা ভাগ করা যায়। অন্যথায়, এটি ফাইলটি ডাউনলোড করতে ফিরে আসে।

const button = document.querySelector('button');
const img =  document.querySelector('img');

// Feature detection
const webShareSupported = 'canShare' in navigator;
// Update the button action text.
button.textContent = webShareSupported ? 'Share' : 'Download';

const shareOrDownload = async (blob, fileName, title, text) => {
  // Using the Web Share API.
  if (webShareSupported) {
    const data = {
      files: [
        new File([blob], fileName, {
          type: blob.type,
        }),
      ],
      title,
      text,
    };
    if (navigator.canShare(data)) {
      try {
        await navigator.share(data);
      } catch (err) {
        if (err.name !== 'AbortError') {
          console.error(err.name, err.message);
        }
      } finally {
        return;
      }
    }
  }
  // Fallback implementation.
  const a = document.createElement('a');
  a.download = fileName;
  a.style.display = 'none';
  a.href = URL.createObjectURL(blob);
  a.addEventListener('click', () => {
    setTimeout(() => {
      URL.revokeObjectURL(a.href);
      a.remove();
    }, 1000)
  });
  document.body.append(a);
  a.click();
};

button.addEventListener('click', async () => {
  const blob = await fetch(img.src).then(res => res.blob());
  await shareOrDownload(blob, 'cat.png', 'Cat in the snow', 'Getting cold feet…');
});

আরও পড়া

ডেমো

এইচটিএমএল

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link
      rel="icon"
      href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🎉</text></svg>"
    />
    <title></title>
    <link rel="stylesheet" href="style.css" />
    <!-- TODO: Devsite - Removed inline handlers -->
    <!-- <script src="script.js" type="module"></script> -->
  </head>
  <body>
    <h1>Share a file</h1>
    <img
      width="200"
      height="200"
      alt="A cat walking in the snow."
      src="cat.png"
    />
    <button type=button></button>
  </body>
</html>

সিএসএস


        :root {
  color-scheme: dark light;
}

html {
  box-sizing: border-box;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

body {
  margin: 1rem;
  font-family: system-ui, sans-serif;
}

img,
video {
  height: auto;
  max-width: 100%;
  display: block;
}

button {
  margin: 1rem;
}
        

জেএস


        const button = document.querySelector('button');
const img =  document.querySelector('img');

const webShareSupported = 'canShare' in navigator;
button.textContent = webShareSupported ? 'Share' : 'Download';

const shareOrDownload = async (blob, fileName, title, text) => {
  if (webShareSupported) {
    const data = {
      files: [
        new File([blob], fileName, {
          type: blob.type,
        }),
      ],
      title,
      text,
    };
    if (navigator.canShare(data)) {
      try {
        await navigator.share(data);
      } catch (err) {
        if (err.name !== 'AbortError') {
          console.error(err.name, err.message);
        }
      } finally {
        return;
      }
    }
  }
  // Fallback
  const a = document.createElement('a');
  a.download = fileName;
  a.style.display = 'none';
  a.href = URL.createObjectURL(blob);
  a.addEventListener('click', () => {
    setTimeout(() => {
      URL.revokeObjectURL(a.href);
      a.remove();
    }, 1000)
  });
  document.body.append(a);
  a.click();
};

button.addEventListener('click', async () => {
  const blob = await fetch(img.src).then(res => res.blob());
  await shareOrDownload(blob, 'cat.png', 'Cat in the snow', 'Getting cold feet…');
});