首页前端开发其他前端知识ckeditor自定义插件使用方法详解

ckeditor自定义插件使用方法详解

时间2024-02-10 12:33:03发布访客分类其他前端知识浏览660
导读:收集整理的这篇文章主要介绍了ckeditor自定义插件使用方法详解,觉得挺不错的,现在分享给大家,也给大家做个参考。 ckedITor是一款功能很强大的富文本编辑的工具,给我们提供了绝大...
收集整理的这篇文章主要介绍了ckeditor自定义插件使用方法详解,觉得挺不错的,现在分享给大家,也给大家做个参考。

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导致。有解决方案的欢迎指导。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

您可能感兴趣的文章:
  • CKEditor扩展插件:自动排版功能autoformat插件实现方法详解
  • FCKeditor 插件开发 示例(详细版本)
  • CKEditor 附插入代码的插件
  • 添加FCKeditor插件需要注意的地方
  • ckeditor插件开发简单实例
  • fckeditor 插件实例 制作步骤
  • autogrow 让FCKeditor高度随内容增加的插件
  • CKEditor中加入syntaxhighlighter代码高亮插件
  • FCKeditor 和 SyntaxHighlighter 代码高亮插件的整合
  • ckeditor一键排版功能实现方法分析

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: ckeditor自定义插件使用方法详解
本文地址: https://pptw.com/jishu/608364.html
CKEDITOR二次开发之插件开发方法 最新版CKEditor的配置方法及插件(Plugin)编写示例

游客 回复需填写必要信息