angular实现链接锚记

前言:

之所以这么说,是因为angular的路由将html默认的链接锚记的#给占用了,所以传统的链接锚记在这里将不再适用,这个有点坑啊,又要多写好几行代码来模拟这个功能。

实现原理:

location.hash()是用来设置页面的标识,在单页应用里因为所有页面都集成到一个页面中,通过路由来实现页面片段的加载,这就需要这个location.hash()来区分。

示例代码:

HTML:

1. 链接锚记触发元素:

<li ng-click="clickLog(item)" ng-repeat="item in HotSiteList">{{item.dataName}}</li>

2. 链接锚记目标元素:

<div ng-repeat="l in letters" ng-if="trainSitesList">
    <div class="site-panel-title padding-left graycolor" id="anchor{{l}}">{{l}}</div>
    ......

JS:

$scope.gotoAnchor = function(x) {
           $location.hash('anchor' + x);
    $anchorScroll();
}

如上,当点击列表项,触发gotoAnchor事件,就会跳转到对应id的div标签

 

转载于:https://www.cnblogs.com/xyyt/p/6860155.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值