锚点跳转偏移位置(当顶部导航设置固定定位时挡住锚点区内容时)

设置虚锚点

<a name="index" style=" position: relative;top: -80px;display: block;height: 0;overflow: hidden;"></a>

 

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>aaaaaaaaaa</title>
 
    <style>
        * {
            margin: 0;
            padding: 0;
        }
 
        .nav {
            width: 70%;
            height: 80px;
            margin: 0 auto;
            background: pink;
            text-align: 80px;
            position: fixed;
            top: 0;
            z-index: 99;
        }
 
        .index {
            width: 100%;
            background: lightseagreen;
            ;
            height: 900px;
        }
 
          .concent{
            width: 100%;
            background: red;
            height: 900px;
        }
 
        .about-us {
            width: 100%;
            background: yellow;
            height: 900px;
        }
      
    </style>
</head>
 
<body>
 
    <!-- 固定导航栏 -->
    <div class="nav">
        <a href="#index" class="font-title font-active">首页</a>
        <a href="#concent" class="font-title">内容</a>
        <a href="#about-us" class="font-title">关于我们</a>
    </div>
 
    <div class="kong" style="height: 80px;width: 100%"></div>
    <div class="main-description">
 
        <!-- 设置暗锚点 -->
        <a name="index" style=" position: relative;top: -80px;display: block;height: 0;overflow: hidden;"></a>
        <!-- 真实锚点显示地方 -->
        <div class="index">首页</div>
 
        <a name="concent" style=" position: relative;top: -80px;display: block;height: 0;overflow: hidden;"></a>
        <div class="concent">内容</div>
 
        <a name="about-us" style=" position: relative;top: -80px;display: block;height: 0;overflow: hidden;"></a>
        <div class="about-us"><span>关于我们</span></div>
       
        <div class="kong" style="height: 80px;width: 100%"></div>
    </div>
 
</body>
 
</html>

 

 

如果是跨页面跳转这样就可

     <a href="a.html#index" class="font-title font-active">首页</a>
        <a href="a.html#concent" class="font-title">内容</a>
        <a href="a.html#about-us" class="font-title">关于我们</a>
    </div>

 

在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标签跳转位置上下偏移的方法。具体的使用方式可以根据实际需求选择合适的方法来实现相应的效果。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值