2

我有一个使用 bootstrap 3.0 的 rails 4.0 站点。工具提示正在显示,但没有样式。引导示例显示标记将如下所示

<div class="tooltip">
  <div class="tooltip-inner">
  </div>
  <div class="tooltip-arrow"></div>
</div>

但是,当我检查它时,生成的标记看起来像是 jQuery 而不是引导程序。

<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>
4

3 回答 3

3

我讨厌这种方式,但我得到了它的工作。我必须添加一个 js 文件,我将其命名为 fix_tooltip.js 并将其添加到其中,$.fn.bstooltip = $.fn.tooltip;然后在我的脚本中调用tooltip$('[data-toggle]').bstooltip();,感觉真的很hacky,不喜欢它。但我无法通过更改 jQuery-UI 工具提示来使其工作。

于 2013-11-13T20:38:51.293 回答
2

我最终得到了以下工作解决方案:

应用程序.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;

其他.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 样式/工具提示

于 2014-04-30T06:39:17.090 回答
0

@tamersalama 的回答帮助我找到了一个简单的解决方案:

不要包含所有 jquery-ui 插件,而只包含您需要的那些(减去工具提示插件)

这是我的 application.js:

//= require jquery
//= require jquery-ui/autocomplete
//= require jquery-ui/datepicker
//= require jquery_ujs
//= require bootstrap
//= require_tree .
于 2014-12-12T08:57:41.547 回答