带有angularjs的Bootstrap工具提示,使用$ http加载工具提示的内容

ana*_*mok 7 tooltip twitter-bootstrap angularjs

我遇到了一个小问题,我似乎无法弄明白.下面的代码有效,除了您第一次将鼠标悬停在链接上.任何帮助是极大的赞赏.

http://jsfiddle.net/LpK6d/1/

<div ng-app="myApp">
<a
    class="pop-over"
    data-original-title="default value"
    data-placement="top">test link</a>
</div> 
Run Code Online (Sandbox Code Playgroud)
var app = angular.module("myApp", []);

app.directive('popOver', function($http) {
  return {
    restrict: 'C',
    link: function(scope, element, attr) {

        element.bind('mouseover', function(e) {
            $http.get("http://ip.jsontest.com/?callback=someFunction")
              .success(function(data) {
                 attr.$set('originalTitle', data);
                 element.tooltip();                  
              });
            })
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

vic*_*tor 4

好吧,.tooltip()在 AJAX 调用之前调用似乎是个好主意,但是该方法将 or 复制data-original-title'title'其内部变量中,因此我们无法更改它:(。

问题是调用 tooltip() 它只是监听 onmouseover 事件。您必须调用.tooltip('show')才能以编程方式显示它。

这是工作小提琴:http://jsfiddle.net/rB5zT/49/

这是正确的方法:

var app =  angular.module("myApp", [])
app.directive('popOver', function($http) {
 return {
  restrict: 'C',
  link: function(scope, element, attr) {
    var i =0;
    element.tooltip();
    $(element).bind('mouseover',function(e) {

        $http.get("test").success(function(){
           attr.$set('originalTitle', "Some text "+i++);  
            element.tooltip('show');
         });
        });
   }
 }
});
Run Code Online (Sandbox Code Playgroud)