是否可以将文件粘贴到输入中?
基本上,我想在计算机/ Internet上复制文件,并将鼠标放在输入区域中,然后在执行Crtl-v(粘贴)时输入会检测到该命令。 有办法吗?
HTML
<div class="card bg-light mb-3" style="width:700px; height:300px">
<div class="card-header">Attachment</div>
<div class="card-body att">
<input type="file" id="files" multiple (change)="detectFiles($event)" accept="image/*">
<div class="grid-container">
<div *ngFor="let url of items">
<div class="grid-item">{{url.fileType}} {{url.filename}}</div><span class="delete" (click)="deleteImage(Imagens[0])"><img>x</span>
</div>
</div>
</div>
</div>
组件
detectFiles(event) {
var files = event.target.files;
for (let index = 0; index < files.length; index++) {
const item: any = {
filename: event.target.files[index].name.split('.')[0],
fileType: event.target.files[index].type.split("image/").join(""),
fileSize: event.target.files[index].size,
number: index
};
this.items.push(item);
this.filename = this.items[0].filename;
this.fileType = this.items[0].fileType;
this.fileSize = this.items[0].fileSize;
console.log(this.items)
const reader = new FileReader();
reader.onload = (e: any) => {
item.url = e.target.result;
}
reader.readAsDataURL(files[index]);
}
}
答案 0 :(得分:1)
您可以从以下内容开始:
在此示例中,您可以通过以下方式进行测试:在本地计算机中复制一些图像,然后使用Ctrl + V(在Mac上为Command + V)将其粘贴到此处。
window.addEventListener("paste", function(e){
var item = Array.from(e.clipboardData.items).find(x => /^image\//.test(x.type));
var blob = item.getAsFile();
var img = new Image();
img.onload = function(){
document.body.appendChild(this);
};
img.src = URL.createObjectURL(blob);
});
<div>Click on the body and press Ctrl-V</div>
注意:请确保您要复制图像,在此示例中我不检查文件类型