主题: 手工添加了几个颜色,为什么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 这里 顺便谢谢小浪子 |
回复 |