如何使用CTRL-V /粘贴将文件粘贴到输入中?

时间:2020-01-16 12:03:24

标签: javascript angular typescript

是否可以将文件粘贴到输入中?

基本上,我想在计算机/ Internet上复制文件,并将鼠标放在输入区域中,然后在执行Crtl-v(粘贴)时输入会检测到该命令。 有办法吗?

DEMO

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]);
      }   

  }

1 个答案:

答案 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>

注意:请确保您要复制图像,在此示例中我不检查文件类型