【发布时间】:2019-12-08 06:35:15
【问题描述】:
我刚刚更新到 chrome 76 stable 并尝试使用新的剪贴板 API 将一些文本(以及稍后的图像)复制到剪贴板。但是,navigator.clipboard.write(data) 似乎不起作用。这是我的代码:
setInterval(function() {
console.log("Wriing to clipbard");
navigator.permissions.query({ name: 'clipboard-write' }).then(result => {
if (result.state === 'granted') {
var data = new Blob(["Text data"], {type : "text/plain"});
navigator.clipboard.write(data).then(function() {
console.log("Copied to clipboard successfully!");
}, function(error) {
console.error("unable to write to clipboard. Error:");
console.log(error);
});
} else {
console.log("clipboard-permissoin not granted: " + result);
}
});
}, 3000);
我在 chrome 扩展内容脚本中运行它,并设置了剪贴板权限,因此权限确实被授予。抛出的错误是:
unable to write to clipboard. Error:
TypeError: Failed to execute 'write' on 'Clipboard': Iterator getter is not callable.
奇怪的是,当我使用navigator.clipboard.write text(text) 而不是navigator.clipboard.write(data) 时,一切正常。问题是,我想使用write(data),因为稍后我也想将图像写入剪贴板。任何想法为什么它不起作用?谢谢。
编辑:我从规格表 https://w3c.github.io/clipboard-apis/#dom-clipboard-write 获得代码
更新:好的,我使用 ClipboardItem 进行文本复制(请参阅下面的答案),但如果我对 dataURL 编码的图像执行相同操作,则整个网页会因“Aw snap”消息而崩溃。所以不确定那里发生了什么。以下是会使网站崩溃并强制重新加载的代码:
setInterval(function() {
console.log("Wriing to clipbard");
navigator.permissions.query({ name: 'clipboard-write' }).then(result => {
if (result.state === 'granted') {
//var blob = new Blob(['hello'], {type: 'text/plain'});
var data = new Blob(["iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNk+P+/HgAFhAJ/wlseKgAAAABJRU5ErkJggg=="], {type : "image/png"});
var item = new ClipboardItem({'image/png': data});
navigator.clipboard.write([item]).then(function() {
console.log("Copied to clipboard successfully!");
}, function(error) {
console.error("unable to write to clipboard. Error:");
console.log(error);
});
} else {
console.log("clipboard-permissoin not granted: " + result);
}
});
}, 3000);
【问题讨论】:
标签: javascript google-chrome-extension clipboard navigator