ckeditor是一款功能很强大的富文本编辑的工具,给我们提供了绝大多数功能,满足我们日常开发所用,但由于特殊情况,可能会需要修改ckeditor的插件。ckeditor提供了给我们很方便扩展插件的接口。
最经由于项目的需要,需要重写ckeditor的上传图片的功能,以下是自定义图片上传功能的部分代码: 
1、在ckeditor/plugins/目录下新建editorupload目录,用来存放自定义插件;在该目录下新建目录images用来存放自定以图片,在images目录下放入插件图片image.png. 

2、在editorupload目录下新建plugin.js:
(function () {
  var a = {
      exec: function (editor) {
        //调用jsp中的函数弹出上传框,
        var url = '../view/fileupload/upload.jsp';
        opendialog({  //opendialog打开一个新窗口
          title: '插入图片',
          url: url,
          height: 600,
          width: 900,
          callback:function(){
          }
        });
      }
    },
    b = 'editorupload';
  ckeditor.plugins.add('editorupload', {
    init: function (editor) {
      editor.addcommand(b, a);
      editor.ui.addbutton('editorupload', {
        label: '添加图片', //鼠标悬停在插件上时显示的名字
        icon: 'plugins/editorupload/images/image.png',  //自定义图标的路径
        command: b
      });
    }
  });
})();
在上面代码中,新建了一个upload.jsp页面用来上传图片,使用了opendialog弹出一个新的窗口,设置了弹出框的高度和宽度。 
ckeditor.plugins.add将自定义的editorupload加入到ckeditor中。
下面是部分upload.jsp页面代码:
<div id="maincontent">
  </div>
  <div class=" box">
    <table class=" m-table">
      <colgroup>
        <col width="20%"/>
        <col width="80%"/>
      </colgroup>
      <tr>
        <td style="vertical-align:top;"><label class="module-name">图片说明</label></td>
        <td>
          <ul>
            <li>1、《pc首页轮播图片》长宽为666×250显示效果最好;《app首页轮播图片》长宽为422×262显示效果最好;</li>
            <li>3、图片提交才会在首页生效;</li>
          </ul>
        </td>
      </tr>
    </table>
  </div>
  <div id="pictures" class="detailwraper nopadding" style="display: none;height: auto;">
    <input id="hidpicturesstatus" type="hidden" value="0"/>
    <input id="hidcurrpictures" type="hidden" value=''/>
    <input id="hiddictsuggestion" type="hidden" value=''/>
    <table>
      <tr>
        <td>
          <div id="filequeue"></div>
          <div id="picwrapper"></div>
          <a id="fake-dlg-bigpic" href="javascript:void(0)" style="display: none;"></a>
          <div id="dlg-bigpic" class="popimg" style="display: none;">
            <a class="leftbtn" href="javascript:void(0)"></a>
            <a class="rightbtn" href="javascript:void(0)"></a>
            <a class="closeimgbtn" href="javascript:void(0)"></a>
            <div class="imglist">
              <ul></ul>
            </div>
          </div>
          <div class="validation-summary-valid">
            <ul>
              <li style="display: none"></li>
            </ul>
          </div>
        </td>
      </tr>
    </table>
  </div>
  <div>
    <button id="fileupload">批量上传</button>
    <button id="submit" class="btn btn-primary" style="vertical-align: top;line-height:23px;width:112px;height: 35px;">提交照片
    </button>
  </div>
</div>
upload.jps页面部分的js代码:
//提交照片
    phototaskdetail.submit = function () {
      var pictures = window.picmanager._getpictures();
      if (pictures.length < 1) {
        alert('请至少上传1张图片');
        return false;
      }
      for (var i in pictures) {
        var imgpath = "<img src='" + staticfileroot + pictures[i].url + "'/>";
        var element = window.parent.ckeditor.dom.element.createfromhtml(imgpath);
        window.parent.ckeditor.instances.editorcontent.insertelement(element);
      }
      parent.closedialog(false);
    }
上面代码中,可以上传多张照片,分别将照片放入到ckeditor中。 
配置ckeditor的config.js:
config.extraplugins += (config.extraplugins ? ',editorupload' : 'editorupload');
ckeditor.editorconfig = function( config ) {
  config.font_names= '宋体/宋体;黑体/黑体;仿宋/仿宋_gb2312;楷体/楷体_gb2312;隶书/隶书;幼圆/幼圆;微软雅黑/微软雅黑;'+ config.font_names;
  config.language = 'zh-cn';
  config.extraplugins += (config.extraplugins ? ',lineheight' : 'lineheight');
  config.extraplugins += (config.extraplugins ? ',editorupload' : 'editorupload');
  ckeditor.config.lineheight_sizes = ckeditor.config.lineheight_sizes +  '30px'; 
  config.height = 650;
  config.toolbarcancollapse = true;
  config.uicolor = '#90b8e9';
  config.toolbar = 'full';
  config.toolbar_full = [
   { name: 'document',  items: [ 'source','-','save','newpage','docprops','preview','print','-','templates' ] },
   { name: 'clipboard',  items: [ 'cut','copy','paste','pastetext','pastefromword','-','undo','redo' ] },
   { name: 'links',    items:['link','unlink']},
   { name: 'insert',   items:['horizontalrule','table','image'] },
   '/',
   { name: 'basicstyles', items: [ 'bold','underline','strike','subscript','superscript','-','removeformat'] },
   { name: 'paragraph',  items: [ 'list', 'indent', 'blocks', 'align', 'bidi' ] },
   { name: 'styles',items: ['lineheight','format','font','fontsize']},
   { name: 'colors',items: ['textcolor', 'bgcolor']},
   { name: 'tools', items : [ 'maximize','editorupload'] }
];
将editorupload插件加入到ckeditor中。 
以下是实现的部分截图: 


实现总结:在自定义插件过程中,必须把原插件的图片插入的功能给打开,负责上传的图片不会被放入到ckeditor中,图片地址会被自动的过滤掉。这可能是ckeditor版本的bug导致。有解决方案的欢迎指导。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持代码网。
 
             我要评论
我要评论 
                                             
                                             
                                             
                                             
                                             
                                            
发表评论