加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – 在页面加载后滚动到锚点

发布时间:2020-12-17 07:44:13 所属栏目:安全 来源:网络整理
导读:我需要设置一个ng-click事件,以便它加载一个新页面,然后,一旦页面加载,滚动到页面上的一个锚点.我已经尝试了在 this SO post提出的每个解决方案,但我无法使其正常工作. 大多数解决方案围绕滚动到已经加载的页面上的锚点.在加载新页面之后,我需要滚动. 这是我
我需要设置一个ng-click事件,以便它加载一个新页面,然后,一旦页面加载,滚动到页面上的一个锚点.我已经尝试了在 this SO post提出的每个解决方案,但我无法使其正常工作.

大多数解决方案围绕滚动到已经加载的页面上的锚点.在加载新页面之后,我需要滚动.

这是我的视图代码:

<div class="see-jobs-btn" ng-click="$event.stopPropagation();goToResultJobs(r)">See Jobs</div>

这表示“个人资料卡”内的按钮.当用户点击卡片时,会将其带到个人资料页面.但是,当他们单击按钮时,需要将它们带到该配置文件页面的#jobs部分(因此代码中的goToResultJobs(r)之前的$stopPropogation()).

这是我的goToResultJobs方法.

$scope.goToResultJobs = function(result) {
    var profileUrl = result.slug;
    window.location = profileUrl;
};

我已经尝试使用$anchorScroll,并将锚点中的硬编码到profileUrl中,但是两者都不起作用.我对于Angular来说很新,所以我不知道我在这里失踪了什么.

更新1:尝试使用$timeout

这是我的ResultsCtrl中的goToResultJobs方法,当用户单击按钮时触发:

$scope.goToResultJobs = function(result) {
    var url = window.location + result.slug + '#jobs';
    location.replace(url);
};

这将加载/ name#jobs路径,调用下面的ProfileCtrl:

app.controller('ProfileCtrl',['$scope','$http','$timeout','$location','$anchorScroll',function($scope,$http,$timeout,$location,$anchorScroll) {
    if(window.location.hash) {
        $timeout(function() {
            console.log('TEST');
            // $location.hash('jobs');
            // $location.hash('jobs');
            $anchorScroll();
        },1000);
    };
}]);

此设置似乎可以正常工作,因为TEST仅在单击作业按钮时才出现在控制台中,但在用户只需单击该配置文件时才会显示.我现在面临的问题是页面开始加载,并且url栏中的路径更改为/ name#作业,但在页面完成加载之前,作业将从URL中删除.因此,当$an??chorScroll()被调用时,哈希中没有锚标签可以滚动到.

所以如上所述,$anchorScroll必须在页面呈现之后发生,否则锚不存在.这可以使用$timeout()来实现.
$timeout(function() {
  $anchorScroll('myAnchor');
});

您可以看到this plunkr.请确保以弹出模式(输出屏幕右上角的小蓝色按钮)查看它.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读