繁体   English   中英

如何使用ngAnimate平滑滚动?

[英]How to smooth scroll with ngAnimate?

我想知道为什么在我的控制器里面这不起作用:

angular.module('app', [
        'ngAnimate',
    ])
    .controller('MainCtrl', function ($scope, $log, $window, $document) {
        var scrollTop = 200 // For example
        angular.element(document).find('body').animate({scrollTop: scrollTop}, 'slow');

    });
});

我只是想平滑地滚动到身体标签顶部的特定偏移。 我是否必须以不同的方式使用ngAnimate

TypeError: angular.element(...)。find(...)。animate不是一个函数

ngAnimate.animate()没有任何关系。 此函数与jQuery有关,而与AngularJS无关。 因此,一个可行的解决方案将如下所示:

angular.module('app', [
        'ngAnimate',
    ])
    .controller('MainCtrl', function ($scope, $log, $window, $document) {
        var scrollTop = 200 // For example
        $('html, body').animate({scrollTop: scrollTop}, 'slow');

    });
});

另外,在加载上面的脚本之前,不要忘记在html文件中加载jquery。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM