我有一个使用bootstrap 3.0的rails 4.0站点。工具提示正在显示但没有样式。引导示例显示标记将如下所示
<div class="tooltip">
<div class="tooltip-inner">
</div>
<div class="tooltip-arrow"></div>
</div>
然而,当我检查它时,生成的标记看起来像是jQuery而不是bootstrap。
<div id="ui-tooltip-18 role="tooltip" class="ui-tooltip ui-widget ui-corner-all ui-widget-content">
</div>
这是我的application.js
//= require jquery
//= require jquery_ujs
//= require turbolinks
//= require twitter/bootstrap
//= require_tree .
这是我的JavaScript调用工具提示
$(function(){
$('[data-toggle=tooltip]').tooltip();
});
这是我在页面上的标记:
<h3>Verifications</h3>
<table>
<% @verification_types.each do |type| %>
<tr>
<td><%= link_to "#{type.name}", '#', data: { toggle: "tooltip" }, title: "Default title" %></td>
</tr>
<% end %>
</table>
答案 0 :(得分:3)
我讨厌这种方式,但我得到了它的工作。我不得不添加一个名为fix_tooltip.js的js文件并将其添加到$.fn.bstooltip = $.fn.tooltip;
,然后在我的脚本中调用tooltip
它现在$('[data-toggle]').bstooltip();
感觉真的很hacky并且不要喜欢它。但我无法通过更改jQuery-UI工具提示来实现它。
答案 1 :(得分:2)
我最终得到了以下工作解决方案:
的application.js
//= require jquery
//= require bootstrap
//= require fix_conflict
//= require jquery.ui.all
//= require jquery_ujs
//= require others
//= require_tree .
fix_conflict.js(感谢@covard)
$.fn.bstooltip = $.fn.tooltip;
others.js
$('.form a').bstooltip();
#IMPORTANT: Make sure to target the exact element on which the tooltip is defined
HTML
<form class='form' ...>
...
<a href='#' data-toggle='tooltip' title="some tooltip text>?</a>
...
</form>
重要:如上所述 - 定位工具提示的 确切元素 非常重要。否则,当使用通用定位$('.form').bstooltip()
时,我最终得到了JQuery样式/工具提示
答案 2 :(得分:0)
@tamersalama的回答帮助我找到了一个简单的解决方案:
不要包含所有jquery-ui插件,而只包括你需要的插件(减去工具提示插件)
这是我的application.js:
//= require jquery
//= require jquery-ui/autocomplete
//= require jquery-ui/datepicker
//= require jquery_ujs
//= require bootstrap
//= require_tree .