我正在开发一个React Web应用程序,其中一项功能需要实现的是在单击图像时复制它,以便用户可以将其粘贴到paint、word等软件中。
我尝试了几种方法,首先遵循这篇文章中详细说明的指令:https://dev59.com/oVwX5IYBdhLWcg3w-DbJ#40547470。
以下是我想出来的代码(containerId 是指包含一个图像元素作为其第一个子元素的 div 元素):
代码已经复制到了图片复制信息处,但是当将其粘贴到 Word 文档中时,它并没有显示出来。另外一个问题是我收到了控制台错误提示:
Uncaught (in promise) DOMException
我尝试了几种方法,首先遵循这篇文章中详细说明的指令:https://dev59.com/oVwX5IYBdhLWcg3w-DbJ#40547470。
以下是我想出来的代码(containerId 是指包含一个图像元素作为其第一个子元素的 div 元素):
copyImg = (containerId) => {
const imgContainerElement = document.getElementById(containerId);
this.selectText(imgContainerElement.children[0]);
document.execCommand('copy');
window.getSelection().removeAllRanges();
alert('image copied!');
}
selectText = (element) => {
var doc = document;
if (doc.body.createTextRange) {
var range = document.body.createTextRange();
range.moveToElementText(element);
range.select();
} else if (window.getSelection) {
var selection = window.getSelection();
var range = document.createRange();
range.selectNodeContents(element);
selection.removeAllRanges();
selection.addRange(range);
}
}
没有起作用。我尝试实现这里标记为2颗星的解决方案:https://www.tek-tips.com/viewthread.cfm?qid=833917
function copyImg(imgId){
var r = document.body.createControlRange();
r.add(document.getElementById(imgId));
r.select();
r.execCommand("COPY");
}
但是createControlRange()未定义。
我尝试使用navigator.clipboard API,但它只适用于png,而该应用程序需要使用jpg。
我寻找了一个可以实现这一点的npm库,但我找到的都是用于复制文本的npm,例如:react-copy-to-clipboard
任何帮助将不胜感激。
编辑1:
按照dw_ https://dev59.com/N7fna4cB1Zd3GeqP0-fA#59183698的说明,这是我想出的解决方法: (注:我必须npm安装babel-polyfill并在App.js中导入它,以使异步函数工作并通过此错误:regeneratorRuntime未定义)
copyImg = async (imgElementId) => {
const imgElement = document.getElementById(imgElementId);
const src = imgElement.src;
const img = await fetch(src);
const imgBlob = await img.blob();
if (src.endsWith(".jpg") || src.endsWith(".jpeg")) {
copyService.convertToPng(imgBlob);
} else if (src.endsWith(".png")) {
copyService.copyToClipboard(imgBlob);
} else {
console.error("Format unsupported");
}
}
convertToPng = (imgBlob) => {
const imageUrl = window.URL.createObjectURL(imgBlob);
const canvas = document.createElement("canvas");
const ctx = canvas.getContext("2d");
const imageEl = createImage({ src: imageUrl });
imageEl.onload = (e) => {
canvas.width = e.target.width;
canvas.height = e.target.height;
ctx.drawImage(e.target, 0, 0, e.target.width, e.target.height);
canvas.toBlob(copyToClipboard, "image/png", 1);
};
}
createImage = (options) => {
options = options || {};
const img = (Image) ? new Image() : document.createElement("img");
if (options.src) {
img.src = options.src;
}
return img;
}
copyToClipboard = (pngBlob) => {
try {
navigator.clipboard.write([
new ClipboardItem({
[pngBlob.type]: pngBlob
})
]);
console.log("Image copied");
} catch (error) {
console.error(error);
}
}
代码已经复制到了图片复制信息处,但是当将其粘贴到 Word 文档中时,它并没有显示出来。另外一个问题是我收到了控制台错误提示:
Uncaught (in promise) DOMException
copyToClipboard
更改为copyService.copyToClipboard
,并将createImage({ src: imageUrl });
更改为copyService.createImage({ src: imageUrl });
。 - dw_Uncaught in promise
错误? - dw_