主题: 手工添加了几个颜色,为什么colorpicker(取色器)无效?
作者: 无忧鱼, 发布日期: 2012-12-18 11:30:58, 浏览数: 4537
在kindeditor.js的colorTable处,在编辑器的工具栏上文字颜色已经生效,但是colorpicker为什么不生效?
作者: Roddy, 发布日期: 2012-12-18 11:54:55
ColorPicker也有自己的配置。
回复
作者: 无忧鱼, 发布日期: 2012-12-18 12:53:34

回复Roddy:

改那里?

回复
作者: Roddy, 发布日期: 2012-12-18 15:01:19
回复无忧鱼:用颜色值搜kindeditor.js呀。
回复
作者: 小浪子, 发布日期: 2012-12-18 15:07:13

其实颜色这块。老大。也应该写成一个单独的文件。

下面是我经常使用的一个JQ的颜色插件:

(function($) {
    var ColorHex = new Array('00', '33', '66', '99', 'CC', 'FF');
    var SpColorHex = new Array('FF0000', '00FF00', '0000FF', 'FFFF00', '00FFFF', 'FF00FF');
    $.fn.colorpicker = function(options) {
        var opts = jQuery.extend({},
        jQuery.fn.colorpicker.defaults, options);
        initColor();
        return this.each(function() {
            var obj = $(this);
            obj.bind(opts.event,
            function() {
                //定位
                var ttop = $(this).offset().top; //控件的定位点高
                var thei = $(this).height(); //控件本身的高
                var tleft = $(this).offset().left; //控件的定位点宽
                $("#colorpanel").css({
                    top: ttop + thei + 5,
                    left: tleft
                }).show();
                var target = opts.target ? $(opts.target) : obj;
                if (target.data("color") == null) {
                    target.data("color", target.css("color"));
                }

                $("#_creset").bind("click",
                function() {
                    target.css("color", target.data("color"));
                    $("#colorpanel").hide();
                    opts.reset(obj);
                });

                $("#CT tr td").unbind("click").mouseover(function() {
                    var color = $(this).css("background-color");
                    $("#DisColor").css("background", color);
                    $("#HexColor").val($(this).attr("rel"));
                }).click(function() {
                    var aaa = $(this).css("background");
                    var color = opts.ishex ? $(this).attr("rel") : aaa;
                    if (opts.fillcolor) target.val(color);
                    target.css("color", aaa);
                    $("#colorpanel").hide();
                    $("#_creset").unbind("click");
                    opts.success(obj, color);
                });

            });
        });

        function initColor() {
            $("body").append('<div id="colorpanel" style="position:absolute;display:none;"></div>');
            var colorTable = '';
            var colorValue = '';
            for (i = 0; i < 2; i++) {
                for (j = 0; j < 6; j++) {
                    colorTable = colorTable + '<tr height="12">';
                    colorTable = colorTable + '<td width="11" rel="#000000" style="background-color:#000000">';
                    colorValue = i == 0 ? ColorHex[j] + ColorHex[j] + ColorHex[j] : SpColorHex[j];
                    colorTable = colorTable + '<td width="11" rel="#' + colorValue + '" style="background-color:#' + colorValue + '">';
                    colorTable = colorTable + '<td width="11" rel="#000000" style="background-color:#000000">';
                    for (k = 0; k < 3; k++) {
                        for (l = 0; l < 6; l++) {
                            colorValue = ColorHex[k + i * 3] + ColorHex[l] + ColorHex[j];
                            colorTable = colorTable + '<td width="11" rel="#' + colorValue + '" style="background-color:#' + colorValue + '">';
                        }
                    }
                }
            }
            colorTable = '<table width=253 border="0" cellspacing="0" cellpadding="0" style="border:1px solid #000;">' + '<tr height=30><td colspan=21 bgcolor=#cccccc>' + '<table cellpadding="0" cellspacing="1" border="0" style="border-collapse: collapse">' + '<tr><td width="3"><td><input type="text" id="DisColor" size="6" disabled style="border:solid 1px #000000;background-color:#ffff00"></td>' + '<td width="3"><td><input type="text" id="HexColor" size="7" style="border:inset 1px;font-family:Arial;" value="#000000"><a href="javascript:void(0);" id="_cclose">关闭</a> | <a href="javascript:void(0);" id="_creset">清除</a></td></tr></table></td></table>' + '<table id="CT" border="1" cellspacing="0" cellpadding="0" style="border-collapse: collapse" bordercolor="000000"  style="cursor:pointer;">' + colorTable + '</table>';
            $("#colorpanel").html(colorTable);
            $("#_cclose").live('click',
            function() {
                $("#colorpanel").hide();
                return false;
            }).css({
                "font-size": "12px",
                "padding-left": "20px"
            });
        }
    };
    jQuery.fn.colorpicker.defaults = {
        ishex: true, //是否使用16进制颜色值
        fillcolor: false, //是否将颜色值填充至对象的val中
        target: null, //目标对象
        event: 'click', //颜色框显示的事件
        success: function() {}, //回调函数
        reset: function() {}
    };
})(jQuery);

 

回复
作者: 无忧鱼, 发布日期: 2012-12-18 15:20:28

回复Roddy:


谢谢,解决了,是_extend(KColorPicker  这里

顺便谢谢小浪子

回复
发表新帖 发表回复