在md-autocomplete上使用ng-blur?

max*_*247 5 javascript angularjs angular-material

我希望在角度材质中构建一个简单的可编辑输入栏,当我点击高光文本时,它将打开一个md-autocomplete,如果我点击外部部分,它将关闭md-autocomplete并显示文本.

<div ng-hide="vm.editableEnabled" ng-click="vm.enableEditorTitle()">
    <span class="hight-light">{{vm.group.name}}</span>
</div>

<md-autocomplete ng-show="vm.editableEnabled"
....
....
ng-blur="vm.disableEditorTitle()">
</md-autocomplete>
Run Code Online (Sandbox Code Playgroud)

Plnkr

但这ng-blur不起作用md-autocomplete.

我知道这是https://github.com/angular/material/issues/3906中的一个问题.我已经尝试了指令解决方案,但它不起作用.

有没有其他好的解决方案来解决这个问题?

谢谢

Jos*_*ush 4

添加了一个名为 的指令,当在其嵌套项目之外单击onClickOutside时,它将触发一个表达式。

另外,请注意,您可以通过直接更改来节省控制器中的功能vm.editableEnabled = true/false


在线演示 - http://plnkr.co/edit/5NlWD2bXFkGPXuj0Awav?p=preview

在此输入图像描述

<div on-click-outside="vm.editableEnabled = false">
  <div ng-hide="vm.editableEnabled" ng-click="vm.editableEnabled = true" ... >
  <md-autocomplete ng-show="vm.editableEnabled" ... >
</div>
Run Code Online (Sandbox Code Playgroud)

javascript:

.directive('onClickOutside', function($timeout) {
    return {
      restrict: 'A',
      scope: {
        onClickOutside: "&"
      },
      link: function(scope, element, attr) {

        angular.element(document).bind('click', function(event) {
          var isChild = childOf(event.target, element[0]);
          if (!isChild) {
            scope.$apply(scope.onClickOutside);
          }

        });

        function childOf(c, p) {
          while ((c = c.parentNode) && c !== p);
          return !!c;
        }
      }

    };

  });
Run Code Online (Sandbox Code Playgroud)