当我单击剑道网格的单元格时,我试图显示剑道拾色器。
我的实际代码要复杂得多,并且大多数是在执行期间生成的。但是,这是我的Kendo Grid特定列编辑器的代码。
editor: function(container, options){
var color = document.createElement('input');
color.setAttribute('type', 'color');
color.setAttribute('id', 'myColorField');
container.show();
$('#myColorField').appendTo(container).kendoColorPicker(
{
buttons: true
}
);
}
我没有任何错误,但是,当我单击单元格进行编辑时,没有出现颜色选择窗口。 (仅当单元格单击时,文本才会消失。) 我对Kendo UI非常陌生。有人可以帮忙吗?
谢谢!
更新:
我将代码更改如下:
editor: function(container, options){
var color = document.createElement('input');
color.setAttribute('type', 'color');
color.setAttribute('class', 'myColorField');
container.show();
$(this).find('.myColorField').appendTo(container).kendoColorPicker(
{
buttons: true
}
);
}
仍然没有运气!
更新:替代方法,但是仍然无法使用!
editor: function(container, options){
$("< input type = 'color' data-bind = 'value:" + prop.Name + "' /> " ).appendTo(container).kendoColorPicker({buttons: true});
}
更新:部分工作代码!
sb.Append(", editor: function(container, options){ " +
"console.log(container);" +
"$(\"< input name = '\"+options.field+\"' /> \" )" +
".appendTo(container)" +
".kendoColorPicker(" +
"{" +
"buttons: true, " +
"value: options.model." + prop.Name+ "," +
"select: function(e) {" +
"options.model." + prop.Name + " = e.value" +
"}" +
"}" +
");" +
"}"
);
我现在可以从颜色选择器中选择颜色并将其设置为我想要的字段。但是,当我尝试打开此颜色选择器时,它看起来很奇怪,并且显示了来自上面代码的标记中的数据。我尝试了很多事情,但是没有任何效果!
更新:没有意外的空格。正确的代码是这样:
"$(\"<input name = '\"+options.field+\"' /> \" )"
代替此:
"$(\"< input name = '\"+options.field+\"' /> \" )"
答案 0 :(得分:2)
这是一个简单的dojo,向您显示将颜色选择器添加到网格中。 https://dojo.telerik.com/aRUsUJOw
更新了dojo: 此图显示了使用新颜色而不是十六进制颜色代码进行样式化的颜色。 https://dojo.telerik.com/aRUsUJOw/4