Javascript 使用AngularJS指令更改div中div的滚动位置

Javascript 使用AngularJS指令更改div中div的滚动位置,javascript,angularjs,scrolltop,angular-directive,tableofcontents,Javascript,Angularjs,Scrolltop,Angular Directive,Tableofcontents,我目前正在开发一个Angular应用程序,它有一个固定高度的嵌套div,其中填充了文本。我想使用外部div上的目录来导航内部嵌套div中的文本。文本和目录都使用ng repeat动态加载。这是我的html <div class="text-nav-main"> <ul class="nav-ul"> <li ng-repeat="item in text.obj" > <span

我目前正在开发一个Angular应用程序,它有一个固定高度的嵌套div,其中填充了文本。我想使用外部div上的目录来导航内部嵌套div中的文本。文本和目录都使用
ng repeat
动态加载。这是我的html

 <div class="text-nav-main">
        <ul class="nav-ul">
            <li ng-repeat="item in text.obj" >
                <span scroll-on-click href="#{{item.id}}" >{{item.title}}</span>
                <ul class="nav-ul">
                    <li ng-repeat="art in item.article">
                        <span scroll-on-click href="#{{art.id}}" >{{art.artNum}}</span>
                        <ul class="nav-ul">
                            <li  ng-repeat="sub in art.subArt">
                                <span scroll-on-click href="#{{sub.id}}" >{{sub.subArtNum}}</span>
                            </li>
                        </ul>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <div class="text-main-window">
            <div ng-repeat="item in text.obj">
                <h3 id="{{item.id}}">{{item.title}}</h3>
                <br/>
                <div ng-repeat="art in item.article">
                    <h4 id="{{art.id}}">{{art.artNum}}</h4>
                    <br/>
                    <div ng-repeat="subArt in art.subArt">
                        <h5 id="{{subArt.id}}" >{{subArt.subArtNum}}</h5>
                        <div ng-repeat="para in subArt.paragraph">
                            <p>{{para.text}}</p>
                        </div>
                        <a ui-sref="rulebook.detail({detail:rules.ruleNumber})" 
                           class="rule-style" 
                           ng-repeat="rules in subArt.rule">
                            {{rules.ruleNumber}} {{rules.ruleName}}<br/>
                        </a>
                        <br/>
                    </div>
                </div>
            </div>
    </div>
目前,链接将我带到嵌套div中的所有位置。当我两次单击同一链接时,它将我带到两个不同的点。如果我在click事件上执行$target.offset().top的console.log,它会给出每个元素的正确位置,但是当我打开animate函数时,一切都会失控。如果我缺少一个简单的解决方案,我很抱歉。我还有很多东西要学,但我就是想不出这一点。提前感谢您的回复。

刚刚找到答案。虽然它没有被标记为已回答的问题,但它应该被标记为已回答的问题。非常感谢

只需要从要滚动到的元素的顶部位置减去嵌套div的顶部位置,然后再加回div的scrollTop位置。我在最终值上加了20 px,只是为了给文本留一点边距

(function(){
'use strict';

angular.module('ganeshaApp')
    .directive('scrollOnClick', function() {
      return {
        restrict: 'A',
        link: function(scope, element, attrs) {
          var idToScroll = attrs.href;
          element.on('click', function() {
            var $target;
            if (idToScroll) {
              $target = $(idToScroll);
            } else {
              $target = element;
            }

            $(".text-main-window").animate({
                scrollTop: $target.position().top - 
                $(".text-main-window").position().top + 
                $(".text-main-window").scrollTop() - 20}, "slow");
          });
        }
      }
});
})();
希望这对其他人有帮助

(function(){
'use strict';

angular.module('ganeshaApp')
    .directive('scrollOnClick', function() {
      return {
        restrict: 'A',
        link: function(scope, element, attrs) {
          var idToScroll = attrs.href;
          element.on('click', function() {
            var $target;
            if (idToScroll) {
              $target = $(idToScroll);
            } else {
              $target = element;
            }

            $(".text-main-window").animate({
                scrollTop: $target.position().top - 
                $(".text-main-window").position().top + 
                $(".text-main-window").scrollTop() - 20}, "slow");
          });
        }
      }
});
})();