首页 > 语言 > JavaScript > 正文

bootstrap-wysiwyg结合ajax实现图片上传实时刷新功能

2024-05-06 14:57:23
字体:
来源:转载
供稿:网友

最近由于项目需求,要实现一个前端文本编辑框,附带图片上传实时查看的功能。比较了网上的几款插件,首先是百度的UEitor,发现该框架过于庞大,一个小框架引入如此多的文件并不是我想看到的;其次是jQuery的easyUI,虽然个人版的是免费的,但是项目属于公司业务,似乎用商业版的框架并不妥。考虑到项目的前端主要就是在bootstrap的基础上构建起来的,最终选用了bootstrap-wysiwyg插件,它非常的精简,轻巧而且扩展性强。

引入bootstrap-wysiwyg并且实现文本编辑功能十分的便捷,但是,我注意到,图片上传是用fileapi实现的。对于大多数网站,虽然用FileApi实现无上传预览用户体验非常好,但是真正存入数据库的时候,我们还是希望能够存储图片的在服务器的静态路径,而并非字符串化的图片。简而言之,我们需要对bootstrap-wysiwyg(以下简称WY)做稍许改写。

首先我们来观察下页面上图片控件,其它的控件略过,查一下源码,很容易发现如下代码:

<div class="btn-group"> <a class="btn" title="Insert picture (or just drag & drop)" id="pictureBtn"> <i class="icon-picture"></i></a>  <input type="file" data-role="magic-overlay"    data-target="#pictureBtn"  data-edit="insertImage" /></div>

做一下说明,data-role,data-target属性是bootstrap中预定义的事件,在这里我们可以理解为布局相关,不用考虑。关键点来了,第三个属性data-edit,bootstrap中并没有这一事件,观察bootstrap-wysiwyg.js,可以发现这样一些代码:

toolbar.find('input[type=file][data-' + options.commandRole + ']')   .change( ...   ...commandRole : 'edit',

也就是说,该属性其实是为了方便选择器而实现的,相当于给图片按钮添加了监听器事件。

我们接着研究一下WY图片预览的实现,第一步,就像上面代码展示的一样,监听器捕捉到fileInput的change事件,做出响应,调用insertFiles函数

restoreSelection();if (this.type === 'file' && this.files && this.files.length > 0) { insertFiles(this.files);}saveSelection();his.value = '';

找到insertFiles函数

insertFiles = function (files) {  editor.focus();  $.each(files, function (idx, fileInfo) {   if (/^image///.test(fileInfo.type)) {   $.when(readFileIntoDataUrl(fileInfo)).done(function (dataUrl) {    execCommand('insertimage', dataUrl);   }).fail(function (e) {    options.fileUploadError("file-reader", e);   });   } else {   options.fileUploadError("unsupported-file-type", fileInfo.type);   }  });  }

我们注意到它使用了jQuery的$.Deferred()方法,先调用了一个readFileIntoDataUrl方法,成功之后通过自封装的execCommand方法实现将图片输出到文本框。该图片其实就是一个<img>标签,只不过src属性是用字符串表示的图片。所以我们要做的其实是在监听器触发之后,将文件上传,获得图片的src,再把链接交给之后的execCommand方法。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选