vue里的锚点定位

例子代码

<template>
  <div class="hello">
    <div class="all" >
      <div class="left">
        <el-timeline>
          <el-timeline-item v-for="(fatherItem, index) in allData" :key="index">
            <a @click="jump(index)">
              {{ fatherItem.moduleName }}
            </a>
          </el-timeline-item>
        </el-timeline>
      </div>
      <div class="right" ref="helloData">
        <div v-for="(fatherItem, index) in allData" :key="'a' + index">
          <div class="firsttitle">{{ fatherItem.moduleName }}</div>
          <div class="zhan-wei"></div>
        </div>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: "HelloWorld",
  data() {
    return {
      msg: "Welcome to Your Vue.js App",
      allData: [
        {
          moduleName: "家庭成员0",
        },
        {
          moduleName: "家庭成员1",
        },
        {
          moduleName: "家庭成员2",
        },
        {
          moduleName: "家庭成员3",
        },
        {
          moduleName: "家庭成员4",
        },
        {
          moduleName: "家庭成员5",
        },
        {
          moduleName: "家庭成员6",
        },
        {
          moduleName: "家庭成员7",
        },
        {
          moduleName: "家庭成员8",
        },
        {
          moduleName: "家庭成员9",
        },
        {
          moduleName: "家庭成员10",
        },
      ],
    };
  },
  methods: {
    jump(index) {
      let jump = document.querySelectorAll(".firsttitle");
      let topUp = jump[index].offsetTop;
      window.scrollTo(0, topUp);
    },
  },
};
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.all {
  display: flex;
}
.left {
  width: 300px;
  position:fixed;
}
.right {
  flex: 1;
  padding-left: 300px;
}
.zhan-wei {
  height: 300px;
  background-color: pink;
  border: 2px solid #ddd;
}
</style>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值