angularjs – Angular UI Bootstrap Popover – 如何添加关闭按钮

前端之家收集整理的这篇文章主要介绍了angularjs – Angular UI Bootstrap Popover – 如何添加关闭按钮前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个桌子,每个单元格都有一个popover,如下例所示:

对popover的电话:

  1. <td ng-repeat="i in c.installments" ng-class="{ 'first' : i.first,'last' : i.last,'advance' : i.advance.value > 0,'edited' : i.edited,'final-installment' : i.last }" popover-trigger="{{ popoverFilter(i) }}" popover-placement="top" popover-title="{{i.id == 0 ? 'Advance' : 'Installment ' + i.id}}" popover-append-to-body="true" popover-template="popoverTemplate(i)" ng-init="payment= i; newpayment= i.amount.rounded_value" >

popover模板:

  1. <script type="text/ng-template" id="editPopoverTemplate.html">
  2. <form name="editPayment">
  3. <h2>{{payment.amount.value|currency:undefined:cents}}</h2>
  4. <div class="form-group" ng-class="{ 'has-error' : editPayment.newpayment.$invalid }">
  5. <label>New value:</label>
  6. <input type="number" name="newpayment" ng-model="newpayment" class="form-control no-spinner" step="1" min="10" required>
  7. <span ng-messages="editPayment.newpayment.$error" class="help-block" role="alert">
  8. <span ng-message="required">The value is mandatory</span>
  9. <span ng-message="min">The value is too low</span>
  10. <span ng-message="max">The value is too hight</span>
  11. </span>
  12. </div>
  13. <div class="btn-group btn-group-justified" role="group">
  14. <div class="btn-group" role="group">
  15. <button class="btn" type="button">Cancel</button>
  16. </div>
  17. <div class="btn-group" role="group">
  18. <button class="btn btn-primary" type="button" ng-disabled="editPayment.$invalid">Save</button>
  19. </div>
  20. </div>
  21. </form>
  22. </script>

working example on plunker

我需要通过popover中的“取消”按钮关闭popover.
这是可能的?我需要扩展Angular UI Bootstrap库来做到这一点?

任何帮助是赞赏.

链接的答案中建议的解决方关闭popover,当用户点击popover内部,或在popover外面,但是我需要通过popover中的“close”按钮关闭它.

使用新的popover-is-open属性的正确解决方案,如下面的@icfantv所述,允许使用控制器作用域.我在 Codepen举行了一个现场演出,就像这样:
  1. app = angular.module('ui.bootstrap.demo',['ui.bootstrap']);
  2.  
  3. app.controller(
  4. 'myPopoverCtrl',['$scope',function($scope) {
  5.  
  6. // query popover
  7. $scope.myPopover = {
  8.  
  9. isOpen: false,templateUrl: 'myPopoverTemplate.html',open: function open() {
  10. $scope.myPopover.isOpen = true;
  11. $scope.myPopover.data = 'Hello!';
  12. },close: function close() {
  13. $scope.myPopover.isOpen = false;
  14. }
  15. };
  16.  
  17. }
  18.  
  19. ]);
  1. <head>
  2.  
  3. <script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
  4. <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
  5. <script src="//maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
  6. <script src="//cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.13.4/ui-bootstrap-tpls.min.js">
  7. </script>
  8. <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
  9.  
  10. </head>
  11.  
  12. <body
  13. ng-app="ui.bootstrap.demo"
  14. class="container">
  15.  
  16. <button
  17. class="btn btn-danger"
  18. ng-controller="myPopoverCtrl"
  19. popover-template="myPopover.templateUrl"
  20. popover-title="This is a popover"
  21. popover-placement="bottom"
  22. popover-is-open="myPopover.isOpen"
  23. ng-click="myPopover.open()">Click me!</button>
  24.  
  25. <script type="text/ng-template"
  26. id="myPopoverTemplate.html">
  27. <h2 ng-bind="myPopover.data" />
  28. <button class="btn btn-success"
  29. ng-click="myPopover.close()">Close me!</button>
  30.  
  31. </script>
  32.  
  33. </body>

原来的答案:

我花了最后两天这个问题,最后想出了一个简单的黑客.这在我的控制器上

  1. $scope.close = function(e) {
  2. el = angular.element(e.target).closest("td"); // `td` is the parent of my clickable
  3. // element,in this case a `span`
  4. $timeout(function() { // need $timeout so we don't conflict with the digest loop
  5. el.children(":first").trigger('close'); // couldn't select the `span` element directly
  6. });
  7. },

现在我们在提供商上设置了关闭触发器:

  1. app.config(['$tooltipProvider',function($tooltipProvider){
  2. $tooltipProvider.setTriggers({
  3. 'click': 'close',// Clicks now only open the tooltip,'close' events close it.
  4. });
  5. }]);

并在我的自定义popover HTML模板:

  1. <button type="button"
  2. class="btn btn-sm btn-success pull-right"
  3. ng-click="close($event)">Close</button>

瞧!我现在可以通过按钮关闭popover了!

猜你在找的Angularjs相关文章