如何使用JavaScript直接上传并预览粘贴板的图片?

(题图:梵高-橄榄树)
提出需求
因为工作原因,现在有一个需求就是需要用户使用QQ或者微信复制一张截图后,在div中直接粘贴这张图片,而不是采用上传的方式。类似我们在使用QQ微信时直接粘贴截图的操作,这个要怎么用js来实现呢?
实现原理
我们可以利用 Clipboard 这个接口API 来实现。
根据在MDN上的定义,Clipboard接口提供了一种读写操作系统剪贴板的方式。这样我们就可以获取剪贴板的内容,然后通过js插入到某个元素中。
具体Clipboard API的MDN链接如下: https://developer.mozilla.org/zh-CN/docs/Web/API/Clipboard
在浏览器兼容性上面,可以看到大体上,常用的浏览器都支持,不过IE就就只能是IE11及以上了。

获取剪贴板的图片
直接上代码了。
//  将粘贴事件绑定到 document 上
document.addEventListener("paste", function (e) {
    let items = event.clipboardData && event.clipboardData.items;
    let file = null;
    if (items && items.length) {
        // 检索剪切板items中类型带有image的
        for (var i = 0; i < items.length; i++) {
            if (items[i].kind === 'file') { // 或者 items[i].type.indexOf('image') !== -1
                file = items[i].getAsFile(); // 此时file就是剪切板中的图片文件
                break;
            }
        }
    }
}, false);
如果复制的是文本的话,可以这样或者粘贴板的文本内容:
let text = null;
if (items && items.length) {
    // 检索剪切板items
    for (let i = 0; i < items.length; i++) {
        // ...
        if (items[i].kind === 'string') {
            text = event.clipboardData.getData('Text'); // 获取文本内容
            break;
        }
    }
}
获取到的是文本内容,可以直接在前端显示。
如果是图片的话,就需要上传到服务器,然后再在前端预览,具体操作往下看。
上传到服务器
如果只是图片,可以直接使用ajax将file保存到服务器即可。
或者通过 FormData 对象进行ajax上传。
let formData = new FormData();
formData.append('file', file); // 将formData上传即可
下次下载之后,通过get方法再次获取到file文件。
let file = formData.get('file');
前端显示预览
上传成功后,我们需要及时在前端看到这个图片,这个可以通过FileReader对象就可以做到。
let reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function (e) {
    let img = document.createElement("img");
    img.src = e.target.result;
    document.body.appendChild(img); // 将图片插入body中
}
或者在html中定义好<img>标签,直接修改图片的src即可
reader.onload = function (e) {
    let img = document.getElementByName("img")[0];
    img.src = e.target.result;
}
注意:这里
e.target.result得到的是图片的Base64格式的地址。
示例demo
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <meta http-equiv="X-UA-Compatible" content="ie=edge" />
        <title>Document</title>
    </head>
    <body>
        <script>
            //  将粘贴事件绑定到 document 上
            document.addEventListener(
                'paste',
                function(e) {
                    let items = event.clipboardData && event.clipboardData.items;
                    let file = null;
                    if (items && items.length) {
                        for (let i = 0; i < items.length; i++) {
                            if (items[i].type.indexOf('image') !== -1) {
                                file = items[i].getAsFile(); // 此时file就是剪切板中的图片文件
                                break;
                            }
                        }
                    }
                    // 如果需要上传后端,只需使用ajax将file上传即可。
                    // 这里是ajax上传操作...
                    if (file.size === 0) {
                        return;
                    }
                    // 上传成功后,在回调函数中设置前端预览
                    let reader = new FileReader();
                    reader.readAsDataURL(file);
                    reader.onload = function(e) {
                        let img = document.createElement('img');
                        img.src = e.target.result;
                        document.body.appendChild(img);
                    };
                },
                false
            );
        </script>
    </body>
</html>
可以直接复制上面demo代码进行实验。
(啾咪 ^.< )
如何使用JavaScript直接上传并预览粘贴板的图片?的更多相关文章
- vue 实现图片上传与预览,以及清除图片
		
vue写原生的上传图片并预览以及清除图片的效果,下面是demo,其中里面有vue获取input框value值的方法以及vue中函数之间的调用 <!DOCTYPE html> <htm ...
 - javascript 图片上传缩略图预览
		
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...
 - html之file标签 --- 图片上传前预览 -- FileReader
		
记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...
 - ASP.NET MVC图片上传前预览
		
回老家过春节,大半个月,在家的日子里,吃好睡好,人也长了3.5Kg.没有电脑,没有网络,无需写代码,工作上相关的完全放下......开心与父母妻儿过个年,那样的生活令Insus.NET现在还在留恋.. ...
 - Jcrop+uploadify+php实现上传头像预览裁剪
		
最近由于项目需要,所以做了一个上传头像预览并且可以预览裁剪的功能,大概思路是上传的图片先保存到服务器,然后通过ajax从服务器获取到图片信息,再利用Jcrop插件进行裁剪,之后通过PHP获取到的四个裁 ...
 - 图片上传本地预览。兼容IE7+
		
基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari 预览地址:http://www.jinbanmen.com/test/1.html js代码:/**名称 ...
 - js上传和预览图片
		
[1].[代码] [HTML]代码 跳至 [1] <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ...
 - DevExpress控件使用系列--ASPxUploadControl(图片上传及预览)
		
1.控件功能 列表控件展示数据.弹框控件执行编辑操作.Tab控件实现多标签编辑操官方说明 2.官方示例 2.1 ASPxImage http: ...
 - uploadPreview 兼容多浏览器图片上传及预览插件使用
		
uploadPreview兼容多浏览器图片上传及预览插件 http://www.jq22.com/jquery-info2757 Html 代码 <div class="form-gr ...
 
随机推荐
- 2018.8.6  Python中的文件操作
			
前言: 使用python来读写文件是非常简单的操作,我们使用open()函数来打开一个文件,获取到文件句柄.然后通过文件句柄就可以进行各种操作了,根据打开方式的不同能够执行的操作也会有相应的差异. 打 ...
 - 练习Markdown基本语法
			
这是一级标题 二级标题 三级标题 我就说一点(数字+英文句点.) 第二 在行首增加*或-,就会有下面的效果 嘿 嘿 嘿 这一部分是插入图片和引用 插入图片 用感叹号+[]+括号 直接复制粘贴~ 引用 ...
 - 《鸟哥的Linux私房菜--基础篇》学习
			
第四章 显示日期与时间的指令:date 输入: (base) liyihuadeMacBook-Pro:~ liyihua$ date 输出: Thu Jun 6 08:44:02 CST 2019 ...
 - LVS NAT模式实践
			
client:192.168.4.10/24 proxy:192.168.2.5/24 192.168.4.5/24 web1:192.168.4.100/24 web2:192.168.4.200/ ...
 - spring session源码解析
			
模块划分 core部分代码 存储实现部分部分: jdbc实现 具体存储的实现类 例如:org.springframework.session.jdbc.JdbcOperationsSessionRep ...
 - csps模拟测试57
			
T1 天空龙 大神题,考察多方面知识,例如:快读 附上考试代码,以供后人学习 应某迪要求,我决定多写一点. 正如文化课有知识性失分和非知识性失分一样,OI也同样存在. 但非知识性失分往往比知识性失分更 ...
 - NOIP模拟测试9
			
又考崩了咕咕咕... T1:随 好题标记 前置芝士: 原根:质数P的原根g满足1<=rt<P,且rt的1次方,2次方…(P-1)次方在模P意义下可以取遍1到(P-1)的所有整数. ...
 - 【转载】InstantRun 原理——深度剖析 AndroidStudio 2.0
			
一.前言 Android Studio 2.0开始支持 Instant Run 特性, 使得在开发过程中能快速将代码变化更新到设备上.之前,更新代码之后需要先编译一个完整的新Apk,卸载设备上已安装的 ...
 - PHP获取PHP执行的时间
			
php获取PHP执行的时间 <pre> //程序运行时间 $starttime = explode(' ',microtime()); //代码区域 //程序运行时间 $endtime = ...
 - 微信APP支付【签名失败】
			
最近在做微信APP支付 遇到一个问题 请求预下单时,接口返回签名错误 由于之前没有成功的交互,刚开始检查程序的错误,经过多次修改,发现依然是签名错误,可能出现的问题如下: 1.该签名密钥不是AppSe ...