1.上传图片至自己的服务器(这个官方都有例子,重点介绍附件上传)
图片上传官方网址

// onChange callback
$('#summernote').summernote({
callbacks: {
onChange: function(contents, $editable) {
console.log('onChange:', contents, $editable);
}
}
}); // summernote.change
$('#summernote').on('summernote.change', function(we, contents, $editable) {
console.log('summernote\'s content is changed.');
})

summernote是一款富文本编辑器,但是他上传的图片的时候,图片会以二进制的形式存入数据库字段中,这时候就很占资源,所以我们希望图片能存入自己的服务器,在字段中就以链接地址的形式存放,这时候就需要在上传图片的时候进行处理,所以callbacks下面的onImageUpload进行图片文件的处理。
示例

//初始化定义
var _this=this;
this.curEle=$('#'+this.id);
var fileUploadBtn=this.template;
this.curEle.summernote({
focus: true,
lang:'zh-CN', //中文说明配置
placeholder:'请输入内容',
fontNames: ['宋体','微软雅黑','楷体','黑体','隶书', 'Arial', 'Arial Black', 'Comic Sans MS', 'Courier New',
'Helvetica Neue', 'Helvetica', 'Impact', 'Lucida Grande',
'Tahoma', 'Times New Roman', 'Verdana'],
height:400,
minHeight:300,
maxHeight:null,
toolbar: [
['style', ['style']],
['font', ['bold', 'italic', 'underline', 'clear']],
['fontname', ['fontname']],
['color', ['color']],
['para', ['ul', 'ol', 'paragraph','height']],
['table', ['table']],
['insert', ['fileBtn','media', 'link', 'picture', 'video']],
['view', ['fullscreen']]
],
buttons: {
fileBtn: fileUploadBtn
},
callbacks: {
onImageUpload: function (files,editor, $editable) {
_this.sendFile(files[0]);
}, }
})
methods:{
sendFile(files){
var _this=this;
var data = new FormData();
data.append("file", files);
$.ajax({
data : data,
type : "POST",
url : SERVICE_URLS.commonUrl.uploadPic.path, //此处为图片上传服务器请求地址,返回的是图片上传后的路径(例如:请求接口为http://120.96.35.20:8090/uploadPic)
cache : false,
contentType : false,
processData : false,
dataType : "json",
success: function(data) {//举例data:{data:'http://www.test.com/a.jpg'}
_this.curEle.summernote('insertImage', data.data);
},
error:function(){
alert("上传失败");
}
});
},
template(context){ //此处为自定义附件上传按钮,如果只考虑图片上传请忽略
let _this=this;
var ui = $.summernote.ui;
// create button
var button = ui.button({
contents: '<i /> 附件',
tooltip: '文件上传',
click: function () {
_this.visibleUpload=true; //控制上传文件界面框可见性
setTimeout(function(){
_this.initUploader(); //初始化web uploader插件
},0) }
});
return button.render(); // return button as jquery object
}
}

2.自定义创建附件按钮,上传至自己服务器。

首先介绍github上已经存在的附件插件
uploadcare-summernotegithub链接地址

这是Summernote WYSIWYG编辑器的Uploadcare插件。它允许您的用户从本地设备,社交网络,云存储上传文件和图像,而无需处理上传所需的任何后端代码。这句话意味着你上传的文件存储的位置不在你自己的服务器上。
当然插件提供了定制存储,有兴趣的可以自己尝试。综合考虑插件的方法有点繁琐不安全,不如自己写个附件上传按钮。

示例如下
(1)创建自己的附件上传按钮 自定义按钮, 如上template函数所示:


(2)上传附件,此处用百度的web uploader插件,具体代码不在细讲(可看web uploader API)
(3)根据返回的数据,动态创建DOM插入到summerNote编辑器中。
这里重点说一下思路:
1.利用插件将本地文件上传到我们的服务器
2.当上传完成后(uploadFinished),我们可根据成功返回的数据,动态的创建DOM对象。
3.将创建好的DOM对象,再插入到编辑器中
(注意:这里不用insertNode方法,因为他会额外的<p><br></p>标签--具体查看issue,另外当选取本地文件的时候,此时的富文本编辑器会失去焦点,插入新的node节点的时候,总是从起始点开始插入,而非从当前光标的位置进行插入。所以尝试换种方法,利用设置code重新置换整个编辑框的内容。)

 initUploader(){
var _this=this;
var $list=$('#uploadList');
var state='pending';
var $btn=$('#toServerBtn');
var uploader = WebUploader.create({
swf: 'https://cdn.bootcss.com/webuploader/0.1.1/Uploader.swf',
server: SERVICE_URLS.commonUrl.uploadFile.path, //自己服务器的文件上传接口
pick: '#fileUpload',
resize: false,
fileNumLimit: 10,
fileSizeLimit: 10 * 1024 * 1024,
});
this.uploader=uploader;
// 当有文件被添加进队列的时候
uploader.on( 'fileQueued', function( file ) {
$list.append( '<li id="' + file.id + '" class="fileItem">' +
'<p class="uploadInfo ellipsis">' + file.name + '</p>' +
'<div class="stateBox">' +
'<p class="uploadState">等待上传</p>' +
'<p class="cancelFile" attr="' + file.id + '" >取消上传</p>' +
'</div>'+
'<div class="progress">' +
'<div class="progress-bar"></div>' +
'</div>'+
'</li>' );
if(file){
_this.ifFileQueue=true;
}
});
$list.on('click','.stateBox .cancelFile',function(event){
var target=event.target.getAttribute('attr');
uploader.removeFile( target,true );
$('#'+target).remove();
var status=uploader.getStats();
if(status.queueNum==0){
_this.ifFileQueue=false
}else{
_this.ifFileQueue=true;
}
})
uploader.on( 'uploadProgress', function( file, percentage ) {
var $li = $( '#'+file.id ),
$percent = $li.find('.progress .progress-bar');
// 避免重复创建
if ( !$percent.length ) {
$percent = $('<div class="progress progress-striped active">' +
'<div class="progress-bar" role="progressbar" style="width: 0%">' +
'</div>' +
'</div>').appendTo( $li ).find('.progress-bar');
}
$li.find('p.uploadState').text('上传中');
$percent.css( 'width', percentage * 100 + '%' );
});
uploader.on( 'uploadSuccess', function( file,response ) {
$( '#'+file.id ).find('p.uploadState').text('已上传');
_this.$set( _this.fileList,_this.fileList.length,response.result[0])
});
uploader.on( 'uploadError', function( file ) {
$( '#'+file.id ).find('p.uploadState').text('上传出错');
});
uploader.on( 'uploadComplete', function( file ) {
$( '#'+file.id ).find('.progress').fadeOut();
});
uploader.on('uploadFinished',function(){ //重点在这里
var str=``;
for (var i = 0; i < _this.fileList.length; i++) {
var item = _this.fileList[i];
str+=`<p><a href="${item.fileUrl}" download="${item.fileName}">${item.fileName}</a></p>`;
}
var storageCode=_this.curEle.summernote('code');
_this.curEle.summernote('reset');
var node=$("<div>"+storageCode+str+"</div>")[0];
// _this.curEle.summernote('insertNode',node); //此处不用insertNode
_this.curEle.summernote('code',node);
setTimeout(()=>{
_this.visibleUpload=false;
},1000)
});
uploader.on( 'all', function( type ) {
if ( type === 'startUpload' ) {
state = 'uploading';
} else if ( type === 'stopUpload' ) {
state = 'paused';
} else if ( type === 'uploadFinished' ) {
state = 'done';
}
if ( state === 'uploading' ) {
$btn.text('暂停上传');
} else {
$btn.text('开始上传');
}
});
$btn.on( 'click', function() {
if ( state === 'uploading' ) {
uploader.stop();
} else {
uploader.upload();
}
});
},

代码没有写全,只是提供思路。

summernote(富文本编辑器)将附件与图片上传到自己的服务器(vue项目)的更多相关文章

  1. vue项目富文本编辑器vue-quill-editor之自定义图片上传

    使用富文本编辑器的第一步肯定是先安装依赖 npm i vue-quill-editor 1.如果按照官网富文本编辑器中的图片上传是将图片转为base64格式的,如果需要上传图片到自己的服务器,需要修改 ...

  2. 使用百度UMeditor富文本编辑器,修改自定义图片上传,修改源码

    富文本编辑器,不多说了,这个大家应该都用到过,至于用到的什么版本,那就分很多种 CKEditor:很早以前叫FCK,那个时候也用过,现在改名了,比较流行的一个插件,国外很多公司在用 UEDITOR:百 ...

  3. wangEditor - 轻量级web富文本编辑器(可带图片上传)

    业务需求: 通过后台编辑文章和图片,上传到前端界面,展示新闻消息模块.这个时候,需要一款简洁的编辑器,百度编辑器是最常用的一种,但是功能太过于复杂,而wangEditor - 轻量级web富文本编辑器 ...

  4. ckeditor富文本编辑器的使用和图片上传,复制粘贴图片上传

    自动导入Word图片,或者粘贴Word内容时自动上传所有的图片,并且最终保留Word样式,这应该是Web编辑器里面最基本的一个需求功能了.一般情况下我们将Word内容粘贴到Web编辑器(富文本编辑器) ...

  5. 百度开源富文本编辑器 UEditor配置:图片上传和文件上传独立使用方法

    使用UEditor编辑器自带的插件实现图片上传和文件上传功能,这里通过配置UEditor单独使用其内置的第三方插件swfupload来实现图片和文件的上传,通过对UEditor配置轻松实现图片批量上传 ...

  6. PHP ckeditor富文本编辑器 结合ckfinder实现图片上传功能

    一:前端页面代码 <script src="/www/res/ckeditor/ckeditor.js"></script> <textarea id ...

  7. vue-quill-editor富文本编辑器,上传图片自定义为借口上传

    vue-quill-editor富文本编辑器,上传图片自定义为借口上传 博客地址:https://blog.csdn.net/lyj2018gyq/article/details/82585194

  8. drupal中安装CKEditor文本编辑器,并配置图片上传功能

    一.下载: 1.CKEditor模块 2.IMCE模块 二.安装       1.复制: 下载完上面两个模块之后,解压,将解压后整个文件夹,复制粘贴,放到 sites\all\modules下面,个人 ...

  9. 使用KindEditor富文本编辑器,点击批量上传按钮没有选择图片按钮

    问题:批量上传没有选择图片按钮

随机推荐

  1. Http的简单介绍

    之前写过一篇使用HttpListener作为简单的HTTP服务器,后面实际项目中就用到了,测试发现,在Win7下如果不是以管理员权限运行程序,使用HttpListener是会出错了. 所以就很好奇HT ...

  2. 分布式的几件小事(十一)分布式session如何实现

    1.分布式会话是什么? 首先,我们知道浏览器有个cookie,在一段时间内这个cookie都存在,然后每次发请求过来都带上一个特殊的jsessionid cookie,就根据这个东西,在服务端可以维护 ...

  3. window.prompt()和 window.confirm()选择

    代码截图: 效果:  代码截图: 效果:

  4. python: 基本数据类型 与 内置函数 知识整理

    列表 list.append(val) #末尾追加,直接改变无返回 list.inert(2,val) #插入到指定位置 list.extend(mylist1) #list会被改变 list2=li ...

  5. Gh0st与云安全

    黑产攻击途径升级,云服务成重灾区 在我们的印象里,黑产以及相关的肉鸡DDOS攻击总是离我们很远.可实际情况并非如此,特别是在云服务大行其道的今天. 日前,腾讯反病毒实验室就观察到了国内云服务中Gh0s ...

  6. Linux添加虚拟网卡的多种方法

    Linux添加虚拟网卡的多种方法有时候,一台服务器需要设置多个ip,但又不想添加多块网卡,那就需要设置虚拟网卡.这里介绍几种方式在linux服务器上添加虚拟网卡. 我们向eth0中添加一块虚拟网卡: ...

  7. Codeforces Round #581 (Div. 2)A BowWow and the Timetable (思维)

    A. BowWow and the Timetable time limit per test1 second memory limit per test256 megabytes inputstan ...

  8. tomcat访问日志

    * %a - Remote IP address # 远程ip地址 * %A - Local IP address # 本地ip地址 * %b - Bytes sent, excluding HTTP ...

  9. Class.forName()方法抛出异常

    在测试static块时间,想要调用Class.forName()来加载类,需要注意此方法要求必须要抛出异常,否则报错. 但在之后却一直抛出java.lang.ClassNotFoundExceptio ...

  10. 【51nod 2026】Gcd and Lcm

    题目 已知 \(f(x)=\sum_{d|x}μ(d)∗d\) 现在请求出下面式子的值 \(\sum_{i=1}^{n}\sum_{j=1}^{n}f(gcd(i,j))∗f(lcm(i,j))\) ...