vue中将新添加的div标签自动定位到可视区域内

可以结合使用Vue的ref和scrollIntoView()方法来实现

html 复制代码
<template>
  <div>
    <button @click="addDiv">添加新的<div>标签</button>
    <div ref="container" class="container">
      <div v-for="(item,index) in divs" :key="index" ref="divElement" class="div-element">
        <!-- 此处为动态添加的div内容 -->
      </div>
    </div>
  </div>
</template>
javascript 复制代码
<script>
export default {
  data() {
    return {
      divs: []
    };
  },
  methods: {
    addDiv() {
      this.divs.push({name:'小明'})
      this.$nextTick(() => {
        const divElement = this.$refs.divElement[this.$refs.divElement.length - 1]; 
        //this.$refs.divElement.length - 1   取的是该数组中的最后一个
        if (divElement) {
          divElement.scrollIntoView({ behavior: 'smooth', block: 'end' });
        }
      });
    }
  }
};
</script>
相关推荐
小满zs28 分钟前
Next.js第十一章(渲染基础概念)
前端
不羁的fang少年1 小时前
前端常见问题(vue,css,html,js等)
前端·javascript·css
change_fate2 小时前
el-menu折叠后文字下移
前端·javascript·vue.js
yivifu2 小时前
CSS Grid 布局详解(2025最新标准)
前端·css
o***Z4483 小时前
前端性能优化案例
前端
张拭心3 小时前
前端没有实际的必要了?结合今年工作内容,谈谈我的看法
前端·ai编程
姜太小白3 小时前
【前端】CSS媒体查询响应式设计详解:@media (max-width: 600px) {……}
前端·css·媒体
weixin_411191843 小时前
flutter中WebView的使用及JavaScript桥接的问题记录
javascript·flutter
HIT_Weston4 小时前
39、【Ubuntu】【远程开发】拉出内网 Web 服务:构建静态网页(二)
linux·前端·ubuntu
百***06014 小时前
SpringMVC 请求参数接收
前端·javascript·算法