移动端 顶部折叠导航 a标签锚点位置偏移

效果如下:点击某个导航后,会跳转到本页面a标签锚点位置。

PC端a标签锚点href="#id"方式,在移动端或者angular下不管用,解决方法如下,待探究原因,欢迎大佬帮忙解释

HTML代码:使用bootstrap导航

<nav id="top-nav" class="navbar navbar-default" role="navigation" style="position: fixed;top: 0;width: 100%;"> 
			<div class="navbar-header">
				<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#menu">
					<span class="sr-only">展开导航</span>
					<span class="icon-bar"></span>
					<span class="icon-bar"></span>
					<span class="icon-bar"></span> 
				</button>
				<a class="navbar-brand" href="#">问诊单</a>
			</div>
			<div class="collapse navbar-collapse" id="menu">
				<ul class="nav navbar-nav">
					<li link="div1" class="active" ng-click="go_menu($event)"><a href="#">第一部分个人基本信息</a></li>
					<li link="div2" ng-click="go_menu($event)"><a href="#">第二部分家族和个人疾病史</a></li>
					<li link="div3" ng-click="go_menu($event)"><a href="#">第三部分个人疾病史治疗情况</a></li>
					<li link="div4" ng-click="go_menu($event)"><a href="#">第四部分生活习惯</a></li>
					<li link="div5" ng-click="go_menu($event)"><a href="#">第五部分身体症状</a></li>
				</ul>
			</div>   
		</nav>
<div id="div1" class="questionnaire-new">这是第一部分内容</div>
<div id="div2" class="questionnaire-new">这是第二部分内容</div>
<div id="div3" class="questionnaire-new">这是第三部分内容</div>
<div id="div4" class="questionnaire-new">这是第四部分内容</div>
<div id="div5" class="questionnaire-new">这是第五部分内容</div>

JS代码:

//angular框架下
 $scope.go_menu=function(event){ 
            //切换导航菜单选中背景色      
            $(".nav").find('li').removeClass('active');
            $(event.currentTarget).addClass('active');
            //隐藏dropdown菜单
            $("#menu").removeClass('in');           
            //获取模块到顶部的距离 
            var id = $(event.currentTarget).attr("link");
            //跳转到对应id
            document.getElementById(id).scrollIntoView();           
        }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue中解决a标签锚点跳转位置上下偏移的方法有很多种,下面我将介绍几种常用的方法。 1. 使用Vue Router的滚动行为功能。在Vue Router中,可以通过设置scrollBehavior属性来控制页面滚动行为。可以通过给目标路由设置一个滚动偏移量来实现锚点跳转时的位置偏移。例如: ```javascript const router = new VueRouter({ mode: 'hash', // 或者其他模式 ... scrollBehavior(to, from, savedPosition) { if (to.hash) { return { selector: to.hash, offset: { x: 0, y: 100 } // 设置纵向偏移量为100px } } } }) ``` 2. 在目标元素上通过ref属性标记,并通过Vue的$refs来操作元素。在Vue的模板中,可以使用ref属性来标记元素,然后可以通过Vue实例的$refs属性来获取到元素的实例,并进行操作。例如: ```html <!-- 模板 --> <a href="#target" @click="scrollToTarget">跳转到目标</a> ... <div ref="target" id="target">目标元素</div> <!-- Vue 实例中的方法 --> methods: { scrollToTarget() { const targetElement = this.$refs.target // 进行滚动操作,可以通过scrollTop属性或者其他滚动方法来控制滚动位置,再加上偏移量即可 } } ``` 3. 使用第三方库来实现滚动行为。除了Vue Router,还有一些第三方库可以用于处理滚动行为,如vue-scrollto、vue-scroll-behavior等。这些库提供了方便的API,可以轻松地控制滚动位置偏移量。可以根据具体需求选择合适的库使用。 总的来说,以上是几种常见的在Vue中解决a标签锚点跳转位置上下偏移的方法。具体的使用方式可以根据实际需求选择合适的方法来实现相应的效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值