在自定义事件上隐藏angular-ui工具提示

时间:2013-11-01 15:58:49

标签: angularjs tooltip angular-ui-bootstrap

我一直在环顾四周,尝试不同的东西,但无法弄清楚。是否可以隐藏某个事件的angular-ui工具提示?

我想要做的是当有人在div上盘旋时显示工具提示,并在用户点击它时关闭它,因为我将显示另一个弹出窗口。我尝试使用自定义触发器事件,但似乎无法使其正常工作。我做了这个:

<div ng-app="someApp" ng-controller="MainCtrl" class="likes" tooltip="show favorites"     tooltip-trigger="{{{true: 'mouseenter', false: 'hideonclick'}[showTooltip]}}" ng-click="doSomething()">{{likes}}</div>

var app = angular.module('someApp', ['ui.bootstrap']);

app.config(['$tooltipProvider', function($tooltipProvider){
 $tooltipProvider.setTriggers({
  'mouseenter': 'mouseleave',
  'click': 'click',
  'focus': 'blur',
  'hideonclick': 'click'
 });
}]);

app.controller('MainCtrl', function ($scope) {
 $scope.showTooltip = true;
 $scope.likes = 999;

 $scope.doSomething = function(){
    //hide the tooltip
    $scope.showTooltip = false;                                   
 };

})

http://jsfiddle.net/3ywMd/

首次点击时工具提示必须关闭而不是第二次关闭。如果用户点击div,你知道如何关闭工具提示吗?

4 个答案:

答案 0 :(得分:6)

我试过@shidhin-cr关于设置$scope.tt_isOpen = false的建议,但它有一个相当重要的问题,虽然工具提示确实淡出,但它仍然存在于DOM中(并处理指针事件! )。因此,即使他们无法看到它,工具提示也可以阻止用户与以前隐藏在工具提示之后的内容进行交互。

我发现更好的方法是简单地触发在工具提示目标上用作工具提示触发器的事件。因此,例如,如果您有一个按钮是工具提示目标,并在点击时触发...

<button id="myButton"
        tooltip="hi"
        tooltip-trigger="click">
</button>

然后在您的JavaScript中,您可以随时触发“点击”。事件,以解雇您的工具提示。在触发事件之前,请确保工具提示实际处于打开状态。

// ... meanwhile, in JavaScript land, in your custom event handler...
if (angular.element('#myButton').scope().tt_isOpen) {
    angular.element('#myButton').trigger('click');
}

由于这会触发AngularUI的Tooltip指令的实际内部,因此您不会遇到上一个解决方案的令人讨厌的副作用。

答案 1 :(得分:4)

基本上,您无法使用工具提示触发器来实现此功能。在深入了解ToolTip指令代码后,我发现ToolTip属性公开了一个名为 tt_isOpen 的范围属性。

因此,在ng-click函数中,如果将此属性设置为false,则会隐藏工具提示。

请参阅此处更新的演示

http://jsfiddle.net/3ywMd/10/

喜欢这个

app.controller('MainCtrl', function ($scope) {
 $scope.likes = 999;
 $scope.doSomething = function(){
    //hide the tooltip
    $scope.tt_isOpen = false;
 };                                    
})

答案 2 :(得分:4)

迈克尔的解决方案让我90%的方式在那里但是当我执行代码时,角度响应了&#34; $摘要已经在进行中#34;。我只是将触发器包裹在超时中。可能不是最好的解决方案,但需要最少的代码

// ... meanwhile, in JavaScript land, in your custom event handler...
if (angular.element('#myButton').scope().tt_isOpen) {
    $timeout( function(){
        angular.element('#myButton').trigger('click');
    }, 100);
}

答案 3 :(得分:1)

为了将来参考,接受的答案angular.element('.yourTooltip').scope().tt_isOpen将无法在新版本中使用,因为工具提示已无法观察。因此,整个牙龈从DOM中移除。简单的解决方案是检查DOM中是否存在工具提示。

借用@ liteflier的答案,

// ... meanwhile, in JavaScript land, in your custom event handler...
if (angular.element('.yourTooltip').length) { //if element is present in DOM
    setTimeout( function(){
        //Trigger click on tooltip container
        angular.element('.yourTooltipParent').trigger('click');
    }, 100);
}