Динамически добавлять всплывающие подсказки к строкам таблицы кендо столбца
У меня есть столбец с некоторыми заметками, отображаемыми в строках. Поскольку заметки огромны, я обрезал заметки в самом контроллере и отправил их на мою страницу aspx. Чего я хочу добиться, так это того, чтобы я отображал полные заметки в виде всплывающей подсказки при наведении курсора мыши на строку сетки (или, если возможно, точно на ячейку). Есть ли способ добиться этого? Любая помощь будет высоко оценен. Заранее спасибо.
2 ответа
Размещение ответа, так как это может помочь кому-либо.
Я получил эту работу после этого...
columns.Bound(p => p.partialNotes).Title("Description").HeaderHtmlAttributes(new { style = "text-align:center" }).HtmlAttributes(new { style = "text-align:left" }).Width("8%").HtmlAttributes(new { title = "#= completeNotes #" });
Я только что добавил HtmlAttributes(new { title = "#= completeNotes #" })
Поэтому теперь, когда я наведу указатель мыши на данные столбца Description, я получаю полные заметки в качестве всплывающей подсказки.
Использование стороннего виджета также возможно. Я добавил подсказки qtip к заголовкам столбцов, как это
Элемент массива столбцов сетки KendoUI
{
field:"property",
headerTemplate:kendo.template($("#h_Entity_property").html())
},
Шаблон заголовка
<link rel="stylesheet" type="text/css" href="lib/Craga89-qTip2-bfcc9ef/dist/jquery.qtip.min.css"/>
<link rel="stylesheet" type="text/css" href="lib/Craga89-qTip2-bfcc9ef/util/qtip.util.css"/>
<script type="text/javascript" src="lib/Craga89-qTip2-bfcc9ef/dist/jquery.qtip.min.js"></script>
<script type="text/javascript" src="lib/Craga89-qTip2-bfcc9ef/util/Dialogues.js"></script>
<script type="text/javascript" src="lib/Craga89-qTip2-bfcc9ef/util/Qtip2Util.js"></script>
<script type="text/x-kendo-template" id="h_Entity_property">
Property
<img onclick="Qtip.local(this, 'i_Entity_property')" src="img/info.gif"/>
<div id="i_Entity_property" style="display:none;">
Elaborate a bit...
</div>
</script>
Генератор подсказок
var Qtip = {
local:function (element, contentId) {
$(element).qtip($.extend({}, qTipSharedOptions, {
content:{
text:$('#' + contentId).html(),
title:{
text:' ',
button:true
}
}
}
));
},
...
};
var qTipSharedOptions = {
position:{
at:'top right', // Position the tooltip above the link
my:'bottom left',
viewport:$(window), // Keep the tooltip on-screen at all times
effect:false // Disable positioning animation
},
style:{
classes:'ui-tooltip-tipsy ui-tooltip-shadow'
},
show:{
ready:true,
event:false,
solo:true // Only show one tooltip at a time
},
hide:false
};
Вы можете сделать как показано ниже:
$("#Kendo-grid-div-id").kendoTooltip({
filter: "td:nth-child(2),td:nth-child(3)", //comma separated multiple columns
position: "bottom", //possible values: bottom,top,left,right,center
content: function(e){
var content = e.target.html();
return content;
}
}).data("kendoTooltip");