如何在AngularJS中观察自定义事件?

14

简单示例:我有一个文本区域并希望为其提供附加行为:在按下 enter 键时执行某些操作,并在按下 shift + enter 时换行到下一行。

我想我应该提供附加指令来添加该行为。 我已经完成了这个:http://jsbin.com/oruvuy/1/edit

P.S. 对我来说,一个奇怪的事情是:我手动调用了 $digest()。 这样可以吗? 有什么想法吗?

JS:

angular.module('Chat', [])
  .directive('enterSubmit', function () {
    return {
      restrict: 'A',
      link: function (scope, element, attrs) {
        var submit;

        $(element).on({
          keydown: function (e) {
            submit = false;

            if (e.which === 13 && !e.shiftKey) {
              submit = true;
              e.preventDefault();
            }
          },

          keyup: function () {
            if (submit) {
              scope.$eval( attrs.enterSubmit );

              // flush model changes manually
              scope.$digest();
            }
          }
        });
      }
    };
  });

function ChatCtrl($scope) {
  $scope.messages = [{
    text: 'Sample Message',
    datetime: new Date()
  }];

  $scope.add = function () {
    $scope.messages.push({
      text: $scope.message,
      datetime: new Date()
    });
    $scope.message = '';
  };

  $scope.message = '';
}
<body ng-controller="ChatCtrl">

  <h1>Leave message:</h1>
  <form>
    <div class='hint'>Click &lt;Enter&gt; to submit :)</div>
    <textarea
      cols="30"
      rows="5"
      ng-model="message"
      enter-submit='add()'
    ></textarea>
    <br />
    <button type="submit" ng-click="add()">Send message!</button>
  </form>

  <h3>Messages list:</h3>
  <table>
    <tr>
      <th>Text</th>
      <th>Date</th>
    </tr>
    <tr ng-repeat="message in messages">
      <td class='text'>{{message.text}}</td>
      <td class='date'>{{message.datetime | date:"HH:mm:ss"}}</td>
    </tr>
  </table>

</body>

但这是正确的做法吗?

1个回答

12

是的,在指令的链接函数中绑定事件正是您想要做的。

调用 $digest 不是 hacky 的做法 - 您的示例中的消息是在 keyup 上添加到模型中的,直到有东西告诉 Angular 才会消化这些更改。它实际上会在下一个 keydown 上被消化,但由于您需要在 keyup 之后发生 $digest,因此必须手动调用它。


非常感谢您的解释。但是我还没有理解事件方面的内容。AngularJS正在监听页面上的所有事件,然后检查每个对象的状态吗?有没有一篇易于理解的文章介绍这方面的知识?我已经在AngularJS上阅读了相关内容,但很难快速理解。 - ValeriiVasin
我推荐这个StackOverflow问题作为一个良好的参考。 - jingman

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接