[转]Kindeditor图片粘贴上传(chrome)
原文地址:https://www.cnblogs.com/jsper/p/7608004.html
首先要赞一下kindeditor,一个十分强大的国产开源web-editor组件。
kindeditor4.1.x版本已支持图片批量上传,不过传统的选文件上传的方式依然效率低下。
很多时候,编辑人员可能需要将一个文档中图片上传到网上,那么,按照传统的上传方法,他必须先将图片另存为到本机,再用编辑器的上传选择文件进行上传。
这个过程至少要做这几个动作:在文档中图片上点右键 -> 点另存为 -> 选择目录 -> 点保存。上传时:点上传按钮 -> 选择目录 -> 选择文件。
可以看到,上传一张图片是十分繁琐的工作,特别时在选择目录的时候,那个小小的文件浏览器界面和千篇一律的文件夹定位,能使人抓狂。
网站编辑人员经常问我能不能从word中直接复制图片粘贴上传?
这个问题我自己也有疑问。带着这个疑问查阅了一些资料,经过学习研究,最终发现,通过很小的代码量就可以实现这个功能。
于是我对kindeditor进行了一下“扩展”。chrome61下测试通过。
通过搜索引擎查阅了一些资料,发现用最新浏览器技术是可以无障碍实现这个想法的。
大体要求及流程是:
1.编写paste粘贴事件的监听处理。
2.从剪切板获取数据。
3.ajax二进制上传。
4.显示到编辑器里。
实现思路是运用kindeditor提供的api+javascript代码结合实现。
把代码写到kindeditor的创建与初始化配置中,最终代码(可重点故关注注释):

1 kindeEditor = KindEditor.create('#updatePapers_contentEditor', {
2
3 /***
4 * 图片上传必须使用绝对路径,因为KindeEditor有个缺陷,
5 * 它的批量上传和单个上传界面文件在不同级别的目录下,
6 * 用相对路径时,总是只能成功一种模式,另一种就不会成功,所以只能这样用绝对路径.
7 */
8 uploadJson : '/fileupload',//服务器文件上传接收程序路径
9 urlType : '',
10 resizeType:0,
11 //调用kindeditor的afterCreate回调函数对kindeditor功能进行“扩展”,实现图片粘贴上传。
12 afterCreate:function() {
13 var editerDoc = this.edit.doc;//得到编辑器的文档对象
14 //监听粘贴事件, 包括右键粘贴和ctrl+v
15 $(editerDoc).bind('paste', null, function (e) {
16 /*获得操作系统剪切板里的项目,e即kindeditor,
17 *kindeditor创建了originalEvent(源事件)对象,
18 *并指向了浏览器的事件对象,而chrome浏览器
19 *需要通过clipboardData(剪贴板数据)对象的items
20 *获得复制的图片数据。
21 */
22 var ele = e.originalEvent.clipboardData.items;
23 for (var i = 0; i < ele.length; ++i) {
24 //判断文件类型
25 if ( ele[i].kind == 'file' && ele[i].type.indexOf('image/') !== -1 ) {
26 var file = ele[i].getAsFile();//得到二进制数据
27 //创建表单对象,建立name=value的表单数据。
28 var formData = new FormData();
29 formData.append("imgFile",file);//name,value
30
31 //用jquery Ajax 上传二进制数据
32 $.ajax({
33 url : '/fileupload?dir=image',
34 type : 'POST',
35 data : formData,
36 // 告诉jQuery不要去处理发送的数据
37 processData : false,
38 // 告诉jQuery不要去设置Content-Type请求头
39 contentType : false,
40 dataType:"json",
41 beforeSend:function(){
42 //console.log("正在进行,请稍候");
43 },
44 success : function(responseStr) {
45 //上传完之后,生成图片标签回显图片,假定服务器返回url。
46 var src = responseStr.url;
47 var imgTag = "<img src='"+src+"' border='0'/>";
48
49 //console.info(imgTag);
50 //kindeditor提供了一个在焦点位置插入HTML的函数,调用此函数即可。
51 kindeEditor.insertHtml(imgTag);
52
53
54 },
55 error : function(responseStr) {
56 console.log("error");
57 }
58 });
59
60 }
61
62 }
63
64
65 });
66 }
67 });

功能虽然有了,但是功能并不是很细致,实际应用中可能还要考虑压缩,图片尺寸缩略。不过这些对于新一代浏览器都不是问题了,都有现成的api调用,可以直接实现。
另外,还不知道其他浏览器(IE9以上、Firefox、Safari等)是否能用。
我在搜索“浏览器粘贴上传”,发现了知乎上的一篇探讨:
《知乎回答问题编辑框用 Ctrl+V 粘贴图片是如何实现的?》https://www.zhihu.com/question/20893119
里面有几位大牛的代码非常吸引我,给了我实现这个功能的最基本要素。
[转]Kindeditor图片粘贴上传(chrome)的更多相关文章
- Kindeditor图片粘贴上传(chrome)
kindeditor4.1.x版本已支持图片批量上传,不过传统的选文件上传的方式依然效率低下. 很多时候,编辑人员可能需要将一个文档中图片上传到网上,那么,按照传统的上传方法,他必须先将图片另存为到本 ...
- js实现图片粘贴上传到服务器并展示
最近看了一些有关于js实现图片粘贴上传的demo,实现如下: (这里只能检测到截图粘贴和图片右键复制之后粘贴) demo1: document.addEventListener('paste', fu ...
- 如何实现一个 markdown 图片粘贴上传的博客后台系统
如何实现一个 markdown 图片粘贴上传的博客后台系统 js 实现 drag & drop / copy & paste image uploader MongoDB 设计文档对象 ...
- ueditor+复制word图片粘贴上传
Chrome+IE默认支持粘贴剪切板中的图片,但是我要发布的文章存在word里面,图片多达数十张,我总不能一张一张复制吧?Chrome高版本提供了可以将单张图片转换在BASE64字符串的功能.但是无法 ...
- KindEditor图片批量上传
KindEditor编辑器图片批量上传采用了上传插件swfupload.swf,所以后台上传文件方法返回格式应为JSONObject的String格式(注). JSONObject格式: JSONOb ...
- ueditor 图片粘贴上传,实现图文粘贴,图片自动上传
如何做到 ueditor批量上传word图片? 1.前端引用代码 <!DOCTYPEhtmlPUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN& ...
- Word图片粘贴上传控件,直接粘贴图片到编辑器-DEDE
很多时候我们用一些管理系统的时候,发布新闻.公告等文字类信息时,希望能很快的将word里面的内容直接粘贴到富文本编辑器里面,然后发布出来.减少排版复杂的工作量. 下面是借用百度doc 来快速实现这个w ...
- kindeditor实现ctrl+v粘贴word图片并上传
Chrome+IE默认支持粘贴剪切板中的图片,但是我要发布的文章存在word里面,图片多达数十张,我总不能一张一张复制吧?Chrome高版本提供了可以将单张图片转换在BASE64字符串的功能.但是无法 ...
- 如何在Chrome粘贴图片直接上传
背景 截图或页面复制图片,可以直接通过Ctrl+v 粘贴上传图片 原理 操作:复制(截图)=>粘贴=>上传 监听粘贴事件=>获取剪贴板里的内容=>发请求上传 浏览器:Chrom ...
随机推荐
- Nginx 反向代理 -- 一路上的坑
前些天刚过来新公司上班,公司的项目都挺多的,只不过项目都是第三方公司团队开发的,现在本公司要组建自己的团队,我作为一个Java后台人员去接手第三方公司的全部项目,我已经是直接崩溃了(先解释一下我崩溃的 ...
- [蓝点ZigBee] Zstack 之点亮OLED液晶 ZigBee/CC2530 视频资料
这一小节主要演示如何在Zstack 下移植液晶驱动,我们选取了目前比较流行的OLED 作为移植目标. 移植关键点 1 修改 GPIO pin, 2 如何将Zstack ...
- 关于js的函数
1.获取内容的兼容函数 /* * 一: 获取内容的兼容函数 * setText(obj, str) * 思路: * 1.首先判断浏览器: * 2.如果是IE浏览器,就用innerText: * 3.如 ...
- vim查找格式
使用了VIM这么久,却一直无法牢记一些基本的操作指令.今天查找一个关键字时,想不起来怎么查找“下一个”,于是google之并解决,顺便把有用的都贴过来罢. 查找指令:/xxx 往下查找?xxx 往上 ...
- C#:前台线程后台线程
1.线程分类 线程由程序员创建,可是创建的方式不同,总体来说有两种,一种是个人构造,也就是使用thread类new线程对象创建,这一类线程是大部分程序员知道的,也叫专用线程;还有一种是由CLR创建,这 ...
- set non-stop on
# Enable the async interface. set target-async 1 # If using the CLI, pagination breaks non-stop. set ...
- 《2019测试面试题-上海悠悠.pdf》
前言 面试测试岗位一般会有笔试题,笔试题考SQL和编程基础比较多,小编最近收集了多家公司的测试面试题,整理成一个文档供大家参考. 2018年下半年一直不太平,听到最多的就是"p2p暴雷&qu ...
- 《软件性能测试与LoadRunner实战教程》喜马拉雅有声图书上线
工作忙的同学们有福了,可以听书了. 于涌老师的<软件性能测试与LoadRunner实战教程>喜马拉雅有声图书上线.
- FakeUserAgentError('Maximum amount of retries reached') 彻底解决办法
报错: FakeUserAgentError('Maximum amount of retries reached') 禁用服务器缓存: ua = UserAgent(use_cache_server ...
- centos找不到环境变量 -bash: ls: command not found
#在系统中输入命令,报如下错误: [root@a1 work]# ll-bash: ls: command not found #昨时解决办法:export PATH=/usr/local/sbin: ...