12

私はAngular.jsを初めて使用し、Angularにタップ、ダブルタップなどのイベントがないことを知っています.Hammer.jsと組み合わせようとしていますが、成功していません.

要点からのコード

/**
 * angular-hammer.js
 * Inspired by AngularJS' implementation of "click dblclick mousedown..." 
 *
 * This ties in the Hammer events to attributes like:
 * 
 *   hm-tap="add_something()"
 *   hm-swipe="remove_something()"
 *
 * and also has support for Hammer options with:
 *
 *  hm-tap-opts="{hold: false}"
 *
 * or any other of the "hm-event" listed underneath.
 */
angular.forEach('hmTap:tap hmDoubletap:doubletap hmHold:hold hmTransformstart:transformstart hmTransform:transform hmTransforend:transformend hmDragstart:dragstart hmDrag:drag hmDragend:dragend hmSwipe:swipe hmRelease:release'.split(' '), function(name) {
  var directive = name.split(':');
  var directiveName = directive[0];
  var eventName = directive[1];
  angular.module('MYMODULE').directive(directiveName, 
  ['$parse', function($parse) {
    return function(scope, element, attr) {
      var fn = $parse(attr[directiveName]);
      var opts = $parse(attr[directiveName + 'Opts'])(scope, {});
      element.hammer(opts).bind(eventName, function(event) {
        scope.$apply(function() {
          console.log("Doing stuff", event);
          fn(scope, {$event: event});
        });
      });
    };
  }]);
});

今、私は自分のhtmlファイルに追加しました

<!--...-->
<script src="/js/jquery-1.9.0.js"></script>
    <script src="/js/angular.js"></script>

    <script src="/js/hammer.js"></script>
    <script src="/js/jquery.hammer.js"></script>
    <script src="/js/angular-hammer.js"></script>

    <script src="/js/app/controllers.js"></script>
</html>

しかし、HTMLで使用しようとすると機能しません。

私は試してみました

<li hmTap="click($event)">...</li>
<li ngTap="click($event)">...</li>
<li hm-tap="click($event)">...</li>
<li ng-tap="click($event)">...</li>

誰も働いていません。この問題を解決できますか?

4

4 に答える 4

25

これを試してみてください。

ソリューションに hammer.js と jquery.hammer.js を追加します。JQuery と Angular を使用。

このようなもの:

<script src="js/jquery/jquery.min.js"></script>
<script src="js/hammer/hammer.js"></script>
<script src="js/hammer/jquery.hammer.js"></script>
<script src="js/angular/angular.min.js"></script>

次に、Angular ディレクティブを使用して新しい HTML 属性を定義します。

この例では、という名前の新しい属性を作成していますon-tap

angular.module('myApp.directives', [])
       .directive('onTap', function () {
         return function (scope, element, attrs) {
           return $(element).hammer({
             prevent_default: false,
             drag_vertical: false
           })
             .bind("tap", function (ev) {
               return scope.$apply(attrs['onTap']);
             });
         };
       });

その後、Hammer イベントごとにディレクティブを作成できます。

ホールド、タップ、ダブルタップ、トランスフォームスタート、トランスフォーム、トランスフォームエンド、ドラッグスタート、ドラッグ、ドラッグエンド、リリース、スワイプ。

HTML は次のようになります。

<button on-tap="DoAngularMethod()">Tap me</button>
于 2013-02-22T12:58:30.567 に答える
9

これがまさにあなたが探しているものです:
https://github.com/wzr1337/angular-gestures

この新しいライブラリを使用すると、必要なすべてのジェスチャを実装できます。
これも読んでください:
http://www.ng-newsletter.com/posts/angular-on-mobile.html

興味深いと思います。:)

于 2014-05-21T08:04:01.777 に答える