近几天公司的后台管理需要图文编辑文章,但是ueditor提供的方法中,本地图片的上传是通过flash的方式处理的,且不支持跨域。若要在已经前后端分离的Angular项目中使用,需要做复杂的环境配置。跟后台人员搞了几个小时后发现这个比较难实行,就算实行也要在前端搭建后台环境,违背了前后端分离的意愿。
最好的解决方法,就是使用原来熟悉的json的post图片的方法,舍弃ueditor默认的方法。死脑筋地搞默认方法实在是费时费力,不如另辟蹊径。
1.首先把自己的<input type='file' />标签做成绝对定位的块,浮在默认方法图标的上方,这样用户就点不到默认的图片上传按键了。
2.然后就按照自己的方法,完成html代码和js代码:
<input type="file" class="form-inline" name="file" onchange="angular.element(this).scope().uploadFile(this.files)"/>
/* 图片上传
* */
$scope.uploadFile = function(files) {
var formData = new FormData();
//Take the first selected file
formData.append("upfile", files[0]);
var url = ser_api.case.uploadImg;
//http上传
var xhr = new XMLHttpRequest();
xhr.open( 'post', url );
xhr.send(formData);
xhr.onreadystatechange = function(){
if (this.readyState == 4 && this.status == 200) {
var res = ser_api.host + this.response;
ser_umeditor.add( '<img class=upload-img src=' + res + ' />'); //用ueditor的方法在文章中插入图片
}
};
};
后台保存成功后,就返回图片在服务器上的url地址,此时自己处理下,插入文章,大功告成。