ckeditor添加自定义按钮整合swfupload实现批量上传图片
给ckeditor添加自定义按钮,由于ckeditor只能上传一张图片,如果要上传多张图片就要结合ckfinder,而ckfinder是收费的,所以就想通过自定义按钮整合swfupload实现一次上传多张图片的功能
首先下载并安装ckeditor。
下载swfupload解压拷贝到对应的文件目录下
3、自定义工具栏按钮:
我们可以自定义ckeditor工具栏要显示的按钮,工具栏按钮定义可以参考这里。
现在我们需要向工具栏添加一个自定义功能的按钮。ckeditor工具栏中的每个按钮都是作为插件定义在ckeditor\plugins\ 目录中。我们在ckeditor\plugins\中创建一个新文件夹imagedef。在imagedef文件夹内,我们创建一个plugin.js文件,它的代码如下:
CKEDITOR.plugins.add(
    "imagedef", {
        requires: ["dialog"], //当按钮触发时弹出对话框
        init: function (a) {
            a.addCommand("imagedef", new CKEDITOR.dialogCommand("imagedef"));
            a.ui.addButton(
                "Imagedef", {
                    label: "图片",
                    command: "imagedef",
                    icon: this.path + "imagedef.gif"
                });
            CKEDITOR.dialog.add("imagedef", this.path + "dialogs/imagedef.js");
        }
    }
);
在上面的代码中我们指定自定义按钮的图标imagedef.gif,imagedef.gif放在imagedef文件夹中。
在imagedef文件夹下新建一个dialogs目录,在dialogs目录下新建一个imagedef.js文件,就是上面代码调用的imagedef.js文件
CKEDITOR.dialog.add(
    "imagedef",
    function (b)
    {
        return {
            title: "图片",
            minWidth: 590,
            minHeight: 300,
            contents: [{
                id: "tab1",
                label: "",
                title: "",
                expand: true,
                padding: 0,
                elements: [{
                    type: "html",
                    html: initImageDlgInnerHtml() //对话框中要显示的内容,这里的代码将发在下面
                }]
            }],
            onOk: function () { //对话框点击确定的时候调用该函数
                    var D = this;
                    var imes = getCkUploadImages(); //获取上传的图片,用于取路径,将图片显示在富文本编辑框中
                    $(imes).each(function () {
                        D.imageElement = b.document.createElement('img');
                        D.imageElement.setAttribute('alt', '');
                        D.imageElement.setAttribute('_cke_saved_src', $(this).attr("src"));
                        D.imageElement.setAttribute('src', $(this).attr("src"));
                        D.commitContent(1, D.imageElement);
                        if (!D.imageElement.getAttribute('style')) {
                            D.imageElement.removeAttribute('style');
                        }
                        b.insertElement(D.imageElement);
                    });
                },
                onLoad: function () { //对话框初始化时调用
                    initEventImageUpload(); //用于注册上传swfupload组件
                },
                onShow: function () {
                    clearCkImageUpload(); //在对话框显示时作一些特殊处理
                }
        };
    }
);
 
接下来我们需要注册imagedef插件。原文中的给出方法是在ckeditor.js中注册,这会使以后升级新版本遇到困难。提倡使用下面的方法在config.js中注册自定义插件:
CKEDITOR.editorConfig = function (config) {
    config.toolbar_Full = [
        ['Source', 'Preview', '-', 'Templates'],

['Cut', 'Copy', 'Paste', 'PasteText', 'PasteFromWord', '-', 'Print', 'SpellChecker', 'Scayt'],
        ['Undo', 'Redo', '-', 'Find', 'Replace', '-', 'SelectAll', 'RemoveFormat'],
        ['Form', 'Checkbox', 'Radio', 'TextField', 'Textarea', 'Select', 'Button', 'ImageButton', 'HiddenField'],
        '/',
        ['Bold', 'Italic', 'Underline', 'Strike', '-', 'Subscript', 'Superscript'],
        ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', 'Blockquote'],
        ['JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock'],
        ['Link', 'Unlink', 'Anchor'],
        ['Imagedef', 'Table', 'HorizontalRule', 'Smiley', 'SpecialChar', 'PageBreak'],
        '/',
        ['Styles', 'Format', 'Font', 'FontSize'],
        ['TextColor', 'BGColor']
    ];
    config.resize_maxWidth = 775;
    config.removePlugins = 'elementspath'; //去掉文本框下面出现body p 等
    config.extraPlugins = "imagedef"; //注册自定义按钮
};

最后,在ckeditor中显示自定义按钮linkbutton,代码如下:
下面代码是在页面上写的,当然可以根据自己的需求来定,写在什么位置

//编辑框初始化上传图片的回调----------自定义按钮插件
//上面有个cke_dialog_start_button_z样式是根据自己的需要来写的
function initEventImageUpload() { //对上传控件的注册
    ckeditorInitSwfu("ck_fs_upload_progress", "stop_id", "ck_btn_id");
    $("#ck_fs_upload_progress").parent().find("object").css({
        "height": "24px",
        "width": "82px"
    });
    $("#ck_btn_start").mouseover(function () {
        $(this).css({
            "cursor": "hand",
            "background-position": "0 -1179px"
        });
    });
}

function clearCkImageUpload() { //对对话框弹出时作特殊处理
    if ($("#ck_fs_upload_progress").html().indexOf(".jpg") != -1) {
        $("#ck_fs_upload_progress").html("");
    }
    $("#ck_pic_div").html("");
}

function getCkUploadImages() {
    return $("#ck_pic_div").find("img");
}
var ckSwfu; //初始化上传控件
function ckeditorInitSwfu(progress, btn, spanButtonPlaceHolder) {
    var uploadUrl = "${BasePath}/commodity_com/img/uploadCommodityImg.ihtml?type=1";
    //在firefox、chrome下,上传不能保留登录信息,所以必须加上jsessionid。
    var jsessionid = $.cookie("JSESSIONID");
    if (jsessionid) {
        uploadUrl += "?jsessionid=" + jsessionid;
    }
    ckSwfu = new SWFUpload({
        upload_url: uploadUrl,
        flash_url: "${BasePath}/res/base/plugin/swfupload/swfupload.swf",
        file_size_limit: "4 MB",
        file_types: "*.jpg;*.png;*.gif;*.jpeg;*.bmp",
        file_types_description: "Web Image Files",
        file_queue_limit: 0,
        custom_settings: {
            progressTarget: progress,
            cancelButtonId: btn
        },
        debug: false,
        button_image_url: "${BasePath}/res/base/plugin/swfupload/button_notext.png",
        button_placeholder_id: spanButtonPlaceHolder,
        button_text: "<span class='btnText'>上传图片</span>",
        button_width: 81,
        button_height: 24,
        button_text_top_padding: 2,
        button_text_left_padding: 20,
        button_text_style: '.btnText{color:#666666;}',
        button_cursor: SWFUpload.CURSOR.HAND,
        file_queued_handler: fileQueuedCk,
        file_queue_error_handler: fileQueueError,
        file_dialog_complete_handler: fileDialogCompleteCk,
        upload_start_handler: uploadStart,
        upload_progress_handler: uploadProgress,
        upload_error_handler: uploadError,
        upload_success_handler: uploadSuccessCk,
        upload_complete_handler: uploadComplete,
        queue_complete_handler: queueComplete
    });
};

//开始上传图片
function ckUploadImageStart(obj) {
    ckSwfu.startUpload();
}

//回调重写
function fileQueuedCk(file) {
    try {
        if ($("#ck_fs_upload_progress").html().indexOf(".jpg") == -1) {
            $("#ck_fs_upload_progress").html("");
        }
        var progress = new FileProgress(file, this.customSettings.progressTarget);
        progress.setStatus("Pending...");
        progress.toggleCancel(true, this);
        $(progress.fileProgressWrapper).css("display", "none");
        $("#ck_fs_upload_progress").append(" " + file.name);

} catch (ex) {
        this.debug(ex);
    }
}

//回调重写,上传成功后
function uploadSuccessCk(file, serverData) {
    try {
        var progress = new FileProgress(file, swfu.customSettings.progressTarget);
        //progress.setComplete();
        //progress.setStatus("上传成功!");
        //progress.toggleCancel(false);
        $(progress.fileProgressWrapper).css("display", "none");
        var json = eval("(" + serverData + ")");
        var img = '<div style="float:left;"><img picUrl="' + json.url + '" src="${BasePath!'
        '}/' + json.url + '" style="width:80px;height:80px"/><a href="javascript:void(0)" onclick="deletePic(this)">X</a></div>';

$("#ck_pic_div").append(img);
        $("#ck_pic_div").dragsort("destroy"); //图片排序,这里要下载dragsort插件
        $("#ck_pic_div").dragsort({
            dragSelector: "div",
            dragBetween: true,
            placeHolderTemplate: "<div class='placeHolder' style='float:left'><img /><a></a></div>"
        });
    } catch (ex) {}
}

//回调重写,主要是设置参数,如果需要的参数没有,就清空上传的文件,为了解决下次选择会上传没有参数时的图片
function fileDialogCompleteCk(numFilesSelected, numFilesQueued) {
    try {

var commoNo = $("#commoNo").val();
        var brandNo = $("#brand option:selected").val();
        var catNo = $("#thirdCommon option:selected").val();
        //初始化上传图片
        if (brandNo != "" && commoNo != "" && catNo != "") {
            this.addPostParam("commoNo", commoNo);
            this.addPostParam("thirdCatNo", catNo);
            this.addPostParam("brandNo", brandNo);
            if (numFilesSelected > 0) {
                document.getElementById(this.customSettings.cancelButtonId).disabled = false;
            }
        } else {
            for (var i = 0; i < numFilesSelected; i++) {
                var promitId = this.customSettings.progressTarget;
                $("#" + promitId).find("*").remove();
                var fileId = this.getFile().id;
                this.cancelUpload(fileId, false);
            }
            $("#ck_fs_upload_progress").html("");
            alert("请选择分类和品牌!");
        }
    } catch (ex) {
        this.debug(ex);
    }
}

ckeditor添加自定义按钮整合swfupload实现批量上传图片的更多相关文章

  1. 调用KEditor批量上传图片

    调用KEditor批量上传图片: <script charset="utf-8" src="/Keditor/kindeditor.js">< ...

  2. CkEditor批量上传图片(java)

    CKEditor上传视频CKEditor批量上传图片flvplayer.swf播放器CKEditor整合包(v4.6.1) ------------------------------------ 最 ...

  3. ecshop编辑器FCKeditor修改成KindEditor编辑批量上传图片

    ecshop一直使用的编辑器是fck,这个不用多说,相信很多朋友用的很悲剧吧,特别是图片不能批量上传图片.     今天小编就分享一下怎么换掉fck,放上实用的kindeditor,最新ecshop版 ...

  4. CKEditor和CKFinder整合实现上传下载功能

    CKEditor与CKFinder整合并实现文件上传功能 事先说明:此整合的是java版本号的, 用到的有:jsp + ckeditor + ckfinder (没有servlet 及其他框架技术) ...

  5. 使用WebUploader客户端批量上传图片,后台使用springMVC接收实例

    使用WebUploader客户端批量上传图片,后台使用springMVC接收实例 我是搞Java后台的,因为最近主管让用webUploader写客户端,但是在网上找了很多,能够复制就能用的并没有几个, ...

  6. 依赖弹出框lhdaiglog的基于WebUploader批量上传图片

    初始上传界面 //链接添加弹窗 html代码段↓ var msgcontent = ""; msgcontent += '<ul class="linkAddBox ...

  7. -Android -线程池 批量上传图片 -附php接收代码

    (出处:http://www.cnblogs.com/linguanh/) 目录: 1,前序 2,类特点 3,用法 4,java代码 5,php代码 1,前序 还是源于重构,看着之前为赶时间写着的碎片 ...

  8. CKEditor与CKFinder整合 MVC3

    今天偶然看到一篇关于 CKEditor与CKFinder整合文章,心想有一段时间没有使用这种东西了.于是乎自己动手亲自体验了一下,本以为简单但在东西编写的过程发现了很多没有遇见毛病. 所以记录一下自己 ...

  9. 使用plupload绕过服务器,批量上传图片到又拍云

    本文最初发布于我的个人博客:Jerry的乐园 综述 论坛或者贴吧经常会需要分享很多图片,上传图片比较差的做法是上传到中央服务器上,中央服务器再转发给静态图片服务器.而这篇文章讲介绍如何使用pluplo ...

随机推荐

  1. jmeter+ant+jenkins+mac 报告优化(三) 使用命令行执行jmeter方式生成多维度的图形化HTML报告

    1.在构建中填写如下命令: 2.start.sh文件的内容 cd /Applications/apache-jmeter-3.0/bin/ CURTIME=`date +%Y%m%d%H%M` ./j ...

  2. Substr函数助你免杀php脚本

    主要利用substr函数和url编解码 本文作者:i春秋签约作家Laimooc 1]安全狗: 新研究的php脚本木马:最新版安全狗扫描如下: 成功看到:扫描已完成,未发现网页木马以及其他威胁(开心吗, ...

  3. JMeter PerfMon Metrics Collector性能监控插件

    官方文档地址https://jmeter-plugins.org/wiki/PerfMon/ JMeter是一款压力测试工具,我们也可以用它来监控服务器资源使用情况. JMeter正常自带可以通过To ...

  4. jQuery的隔行换色

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  5. L06-Ubuntu系统中部署Vagrant和VirtualBox

    一.前言 1.Vagrant是一个搭建完整的虚拟开发环境的工具~~~更多关于Vagrant理论可查看这篇博文https://www.cnblogs.com/davenkin/p/vagrant-vir ...

  6. [原创] PHP 使用Redis实现锁

    目录 锁实现的注意点 加锁 connect 与 pconnect 解锁 Redis 中使用 Lua 脚本的注意点 Redis集群分布式锁 RedLock 算法 锁实现的注意点 互斥: 任意时刻, 只能 ...

  7. 【kuangbin】计算几何部分最新模板

    二维几何部分 // `计算几何模板` ; const double inf = 1e20; const double pi = acos(-1.0); ; //`Compares a double t ...

  8. Mybatis中的@Param注解

    前言 今天在使用Mybatis时遇到一个问题,主要出错原因在于Mybatis的@Param注解,如果我不在参数前面加上@Param注解,数据库操作就会报错,如下: @Param作用 @Param注解的 ...

  9. Java NIO学习与记录(五): 操作系统的I/O模型

    操作系统的I/O模型 在开始介绍NIO Reactor模式之前,先来介绍下操作系统的五种I/O模型,了解了这些模型,对理解java nio会有不小的帮助. 先来看下一个服务端处理一次网络请求的流程图: ...

  10. Eclipse下,修改MAVEN 中央仓库地址,解决maven下载慢问题

    作用于所有工作空间: 1.逐项打开:eclipse->preference->Maven->User Settings.按窗口中的User Settings文本框显示的路径,创建se ...