UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码。(抄的...)

UEditor是非常好用的富文本web编辑器,而且全中文API和注释,方便学习和使用。特别是图片上传查看及涂鸦功能极为喜欢,但是有很多情况我们并不需要Web编辑器,而只需要图片上传。那么问题来了,提取图片上传哪家强.....

网上有很多图片上传的控件、插件。但都不是那么的完美,有的只有一张图片上传不包含批量上传,有的没有图片查看功能,还有的必须要flash的支持(ios系统就悲剧了),当然还有的不能跨语言,还有上传没有状态显示,当然还有客户体验不是太好, 浏览器兼兼容问题就更多了,在线涂鸦更是少之又少。而UEditor上传图片几乎解决了以上的问题。

废话不多说,走起。

一、从官网(http://ueditor.baidu.com/website/download.html)上下载UEditor选择开发版[1.4.2 .Net 版本],1、因为本人.Net。2、老的版本更稳定,新版本不支持ie8以下版本。关于其他语言的开发其实和.Net一样,主要是思路。

二、按照官网的说明文档(http://fex-team.github.io/ueditor/)把UEditor部署到VS(http://fex-team.github.io/ueditor/#server-net)中,保证UEditor可以正常使用,特别是图片上传功能。本文主要讲解单独提取UEditor图片上传功能,所以对UEditor的使用部署请参考官网(http://ueditor.baidu.com)。图是本人在VS中的目录结构。

三、修改config.json相关配置信息,这个配置主要关于上传以及查看图片的相关配置。

四、修改ueditor.config.js中的toolbars以及serverUrl ,我们只显示多图片单图片以及涂鸦的显示。

  1. // 服务器统一请求接口路径
  2. , serverUrl: URL + "../../Common/controller.ashx"
  3.  
  4. //工具栏上的所有的功能按钮和下拉框,可以在new编辑器的实例时选择自己需要的从新定义
  5. , toolbars: [[ 'insertimage', 'scrawl', 'simpleupload' ]]

五、我们的主要内容是创建自己的通用提取上传图片的js文件(custom.js)和简单修改UEditor的ueditor.all.js文件。

  1)、我们在页面中添加UEditor显示Div[editor-img]以及我们后面要处理上传完以后处理文件的名称[temp-img-list],还有初始化Ueditor。

  1. $("body").append(" <div id=\"editor-img\" style=\"display:none\"></div><div id=\"temp-img-list\" style=\"display: none\"></div>");
  2. var ue = UE.getEditor('editor-img');

  2)、我们可以把div id='editor-img'的display='block'显示,然后我们就可以在页面看到完整的包含图片上传多图片上传以及涂鸦的UEditor了。

   3)、我们在页面Default.aspx中定义一个多图片上传按钮a标签,然后调用uploadImgs()方法,我们要做的就是点击a标签触发UEditor多图片上传按钮,我们查看源码可以到多图片上传按钮的div class 为edui-for-insertimage,如图。然后我们点击a标签就弹出图片上传的窗口了。

  1. function uploadImgs() {
  2. $(".edui-for-insertimage .edui-button-body")[0].click();
  3. }

 

    

    

    我们这时可以上传图片以及在线查看图片了。然后点击确认。。。。。。我们这时点击确认会发现会把图片加载到UEditor中,这并不是我们想要的,我们已经完成把图片上传到服务器了,现在只要知道我们上传了哪些图片或者查看图片时选择了哪些图片的名称就完成我们所需要的了。

  4)、当点击确认时图片加载到编辑器中,编辑器的内容就会发生变化。我们可以监听编辑器内容的变化然后再获取编辑器中的内容进行分析处理即可获取图片名称。我们查看官方API可以找到contentChange事件(编辑器内容发生改变时会触发该事件),然后监听此事件。由于单个图片上传相比批量上传和涂鸦比较复杂,我们稍后再做详解。

  1. UE.getEditor('editor-img').addListener('contentChange', function (editor) {
  2. //获取编辑器中的内容(html 代码)
  3. var img = UE.getEditor('editor-img').getPlainTxt();
  4. if (img != "") {
  5. //把编辑器中的内容放到临时div中,然后进行获取文件名称。
  6. $("#temp-img-list").html(img);
  7. var array = new Array();
  8. //循环获取文件名称
  9. $("#temp-img-list img").each(function () {
  10. var src = $(this).attr("src");
  11. var name = src.replace("/upload/image/", "");
  12. array.push(name);
  13. });
  14. //清空编辑器中的内容,以便下一次添加图片。
  15. UE.getEditor('editor-img').execCommand('cleardoc');
  16. //调用callbackImg获取懂图片名称
  17. if (typeof callbackImg === "function") {
  18. eval("callbackImg('" + array + "')");
  19. }
  20.  
  21. }
  22. });

   5)、我们自定义js方法callbackImg就可以获取到图片名称了

  1. function callbackImg(imgName) {
  2. var names = imgName.split(",");
  3. for (var i = 0; i < names.length; i++) {
  4. $("#show-img-name").append($("<div></div>").html($("<a></a>").html(names[i]).attr("href", "/upload/image/" + names[i] + "").attr("target", "_blank")));
  5. }
  6. }

  6)、这样一个完整的批量图片上传查看的功能就完成了。同理我们可以添加涂鸦的功能,其实这这一步涂鸦的功能只要一步即可,自定义一个js方法insertScrawl(),然后调用insertScrawl即可完成涂鸦的功能。

  1. function insertScrawl() {
  2. $('.edui-for-scrawl .edui-button-body')[0].click();
  3. }

  到此为止,我们就完成了批量图片上传和涂鸦功能。

六、通读代码其实发现批量图片上传和涂鸦就是简单的模拟按钮调用,然后上传完图片或者选择完图片然后点击确认回调处理编辑器中的内容获取文件名称。但是单独上传图片会有一定的复杂度。

  1)、我们用UEditor上传单个图片时会发现在编辑器中会有个等待的图片,当图片上传完毕以后会把等待图片换成我们上传的图片。

  

  上传中...

  

  上传完成以后。

  2)、那么问题又来了,问题一,我们原来是监听编辑器中文本变化,然后获取其中的图片提取名称,这时我们获取的是等待的图片而不是我们真正上传的图片。问题二,这时上传并没有状态显示,如果图片过大或者网速不是很好的情况下,导致用户体验不是很好。

    解决这些问题我们首先要找到图片刚开始上传和上传完毕的事件,还有要判断编辑器中的图片是否是等待的图片,反之就是我们上传的图片。

      1)、查找源码我们可以在ueditor.all.js中找到上传开始和上传完成的事件,分别在24379行和24390行,在ueditor.all.js中分别调用js方法preUploadSingleImg()和uploadSingleImgCallback()。

      2)、ueditor.all.js中修改代码(1,2,3行,23,24,25行)

  1.       if (typeof preUploadSingleImg === "function") {
  2. preUploadSingleImg();
  3. }
  4. function callback() {
  5. try{
  6. var link, json, loader,
  7. body = (iframe.contentDocument || iframe.contentWindow.document).body,
  8. result = body.innerText || body.textContent || '';
  9. json = (new Function("return " + result))();
  10. link = me.options.imageUrlPrefix + json.url;
  11. if(json.state == 'SUCCESS' && json.url) {
  12. loader = me.document.getElementById(loadingId);
  13. loader.setAttribute('src', link);
  14. loader.setAttribute('_src', link);
  15. loader.setAttribute('title', json.title || '');
  16. loader.setAttribute('alt', json.original || '');
  17. loader.removeAttribute('id');
  18. domUtils.removeClasses(loader, 'loadingclass');
  19. } else {
  20. showErrorLoader && showErrorLoader(json.state);
  21. }
  22. //单独提取上传回调函数。
  23. if (typeof uploadSingleImgCallback === 'function') {
  24. uploadSingleImgCallback();
  25. }

     3)、在自定义js custom.js中添加方法

  1. //单传图片开始上传,显示等待。
  2. function preUploadSingleImg() {
  3. if ($("#loading").length > 0) {
  4. $("#loading").html("<img src='/Scripts/ueditor/loading.gif'>");;
  5. }
  6.  
  7. }
  8.  
  9. //单传图片回调,隐藏等待图片
  10. function uploadSingleImgCallback() {
  11. if ($("#loading").length > 0) {
  12. $("#loading").empty();
  13. }
  14. }

    4)、最后要做的就是在页面上添加一个空的div id='loading'

     5)、这样我们就解决了单独图片上传状态的问题,但是还有一个获取编辑器中上传图片的问题,这时要做两步,

        1)、在custom.js中修改代码,编辑器内容改变事件中contentChange 判断是否是等待图片,如果是等待图片我们不做任何的处理即可。修改代码为

  1. UE.getEditor('editor-img').addListener('contentChange', function (editor) {
  2. //获取编辑器中的内容(html 代码)
  3. var img = UE.getEditor('editor-img').getPlainTxt();
  4. if (img != "") {
  5. //判断是否是单图片上传,如果是单传不做任何处理,等待回调函数再次调用。
  6. if (img.indexOf("loadingclass") == -1) {
  7. //把编辑器中的内容放到临时div中,然后进行获取文件名称。
  8. $("#temp-img-list").html(img);
  9. var array = new Array();
  10. //循环获取文件名称
  11. $("#temp-img-list img").each(function () {
  12. var src = $(this).attr("src");
  13. var name = src.replace("/upload/image/", "");
  14. array.push(name);
  15. });
  16. //清空编辑器中的内容,以便下一次添加图片。
  17. UE.getEditor('editor-img').execCommand('cleardoc');
  18. //调用callbackImg获取懂图片名称
  19. if (typeof callbackImg === "function") {
  20. eval("callbackImg('" + array + "')");
  21. }
  22. }
  23. }
  24. });

        2)、我们在上传完事件中清空编辑器中的内容,然后编辑器又会调用 contentChange 事件,由于上传完毕以后编辑器中不是等待的图片而是我们真正上传的图片,这时只要按照多图片上传获取图片名称即可。修改方法uploadSingleImgCallback为

  1. //单传图片回调,然后清理内容,在清理内容会自动调用contentChange事件,然后再获取上传文件的文件名。
  2. function uploadSingleImgCallback() {
  3. UE.getEditor('editor-img').execCommand('cleardoc');
  4. if ($("#loading").length > 0) {
  5. $("#loading").empty();
  6. }
  7. }

    6)、最后我自定义一个按钮调用方法uploadImg()即可弹出窗口选择图片,然后选择图片点击确定即可上传到服务器并获取到文件名称。

  1. function uploadImg() {
  2. $(".edui-for-simpleupload input").click();
  3. }

    

总结:我们选择就从UEditor中提取了多图片单图片上传以及涂鸦的功能。关于其他语言,逻辑一样的,只要更换不同的服务端代码即可。

以下为动画演示

谢谢观赏...

Github:https://github.com/Emrys5/UeditorFileUpload

    

    

从web编辑器 UEditor 中单独提取图片上传,包含多图片单图片上传以及在线涂鸦功能的更多相关文章

  1. 【ASP.NET 插件】分享一款富文本web编辑器UEditor

    UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码... <%@ Page Language ...

  2. 强大的在线web编辑器UEditor

    UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码. UEditor在线演示地址:http://u ...

  3. 推荐一个很好的富文本web编辑器UEditor

    前天产品提了一个编辑器的bug,本人找是找到了问题的症结,就是不好改.框架是压缩兼混淆后的代码.查一下,好多年前的框架... 咨询了一个同事有关旧框架的事情,他也建议我升级编辑器并帮忙帮我找了UEdi ...

  4. MVC项目中应用富文本编辑器UEditor中的几个坑

    UEditor:百度出品 官网连接:http://ueditor.baidu.com/website/ 错误现象:在官网上复制到本地后,上传图片功能不能用, 控制台提示:“请求后台配置项http错误, ...

  5. 关于百度编辑器UEditor的一点说明

    大家在使用的时候要特别注意editor_config.js中的“URL”这个参数 我的理解:1.这个参数是editor整个结构的总路径          2.首先要把这个路径配置好了.才能正常的显示, ...

  6. 百度富文本编辑器UEditor安装配置全过程

    网站开发时富文本编辑器是必不可少的,他可以让用户自行编辑内容的样式然后上传到后台!下面我们来介绍如何安装使用百度富文本编辑器 一.下载并且设置百度富文本编辑器的样式     你可以去百度UEditor ...

  7. 百度Web富文本编辑器ueditor在ASP.NET MVC3项目中的使用说明

    ====================================================================== [百度Web富文本编辑器ueditor在ASP.NET M ...

  8. FLASH图片上传功能—从百度编辑器UEditor里面提取出来

    为了记录工作中碰到的各种问题,以及学习资料整理,今天开始,将以往的文章进行了一个整理,以后也开始认真的记录学习过程中的各种问题 在HTML里面的文件上传功能一直是个问题,为了实现上传文件大小限制,怎样 ...

  9. ueditor百度编辑器中,多图上传后,图片顺序乱掉的处理方法

    上传后,图片的顺序和预期的不一致,需要修改ueditor的源码. 一.找到editor/dialogs/attachment/attachment.js文件 1.将_this.fileList.pus ...

随机推荐

  1. Python字符进度条

    Python字符进度条 看看这个神奇的module from tqdm import trange from time import sleep for r in trange(10, 1, -1): ...

  2. seajs模块化开发

    seajs是一个起辅助作用的库,所以它可以更方便开发,而它可以解决以下问题: 1.命名问题,就是冲突 2.性能问题,就是只要一个功能,但却使用一个大插件中的一个小功能,所以要手动拆分出这个功能 3.j ...

  3. 《Qt Quick 4小时入门》学习笔记

    http://edu.csdn.net/course/detail/1042/14804?auto_start=1   Qt Quick 4小时入门 第五章:Qt Quick里的信号与槽   QML中 ...

  4. dubbox

    github源码: https://github.com/dangdangdotcom/dubbox maven中央仓: 无 获取分支 git clone -b dubbox-2.8.4 https: ...

  5. (原创)详解KMP算法

    KMP算法应该是每一本<数据结构>书都会讲的,算是知名度最高的算法之一了,但很可惜,我大二那年压根就没看懂过~~~ 之后也在很多地方也都经常看到讲解KMP算法的文章,看久了好像也知道是怎么 ...

  6. Tomcat7.0启动报错:java.lang.illegalargumentexception:taglib definition not consisten with specification version

    Tomcat7.0启动报错:java.lang.illegalargumentexception:taglib definition not consisten with specification ...

  7. Web 前端开发精华文章集锦(jQuery、HTML5、CSS3)【系列十八】

    <Web 前端开发精华文章推荐>2013年第六期(总第十八期)和大家见面了.梦想天空博客关注 前端开发 技术,分享各种增强网站用户体验的 jQuery 插件,展示前沿的 HTML5 和 C ...

  8. web基础---->request的请求参数分析

    当contentType为application/json的时候,在servlet中通过request.getParameter得到的数据为空.今天我们就java的请求,分析一下request得到参数 ...

  9. java io系列16之 PrintStream(打印输出流)详解

    本章介绍PrintStream以及 它与DataOutputStream的区别.我们先对PrintStream有个大致认识,然后再深入学习它的源码,最后通过示例加深对它的了解. 转载请注明出处:htt ...

  10. 别用symbolicatecrash来解析crash Log了

    今天突然发现了一个解析iOS crash log的好方法,忍不住来分享一下. 相信每个做iOS开发的TX都应该不会对symbolicatecrash陌生,我们第一次遇到真机上产生的崩溃日志时,在网上搜 ...