Vue - 详细实现动态改变元素容器(非页面body)滚动条位置,在一个容器内设置滚动条,并通过 js 改变滚动条位置教程(设置指定子元素div的滚动条位置)

167 篇文章 1201 订阅 ¥9.90 ¥99.00

前言

如果您遇到了 Vue 页面缓存(keep-alive)返回后滚动条回到了顶部,不在原来的位置了(从详情页返回列表时发现滚动条位置回到了最顶部,滚动条并没有停留在进入详情页之前),请访问:这篇文章。

在 vue2 / vue3 / nuxt 网站开发中,实现容器内滚动条位置的修改,利用 js 直接修改某个容器内的滚动条所在位置。

例如您有一个子元素容器(非body),并将其设置了最大高度,

当内容溢出后会出现滚动条,您想要 动态控制 该滚动条的位置。


网上大部分文章都是页面(body)滚动相关,没有 指定元素容器(div) 的内容,

本文带您从 0-1 实现一个动态更改滚动条位置的例子,如下图所示:

在这里插入图片描述

解决方案

推荐使用平台一键复制功能,避免漏选。

您随便找个页面,运行起来即可。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
vue-drag-resize 是一个用于实现拖拽和缩放功能的 Vue 组件库,如果您想要让拖拽和缩放的元素容器中间,可以通过一些 CSS 样式来实现。 假设您的容器一个固定宽高的 div,您可以将该 div 设置为相对定位(position: relative),并将拖拽和缩放的元素设置为绝对定位(position: absolute)。然后,通过计算元素的宽高以及容器的宽高,可以将元素定位到容器中间。 具体的实现方法如下: ```html <template> <div class="container"> <vue-drag-resize :w="width" :h="height" :x="x" :y="y" @dragging="onDragging" @resizing="onResizing"> <!-- 元素内容 --> </vue-drag-resize> </div> </template> <script> export default { data() { return { width: 100, height: 100, x: 0, y: 0 } }, methods: { onDragging(event) { // 拖拽事件处理 }, onResizing(event) { // 缩放事件处理 } } } </script> <style> .container { position: relative; width: 500px; height: 500px; } .vue-drag-resize { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); } </style> ``` 在上面的示例中,将容器设置为相对定位,并将拖拽和缩放的元素设置为绝对定位。通过将元素的 left 和 top 设置为 50%,再通过 transform 属性将元素向左和向上移动宽度和高度的一半,就可以将元素居中在容器中了。 需要注意的是,这种方法仅适用于容器元素的宽高已知并且固定的情况。如果容器元素的宽高不固定,或者容器的宽高是相对于父元素的百分比,那么需要通过 JavaScript 计算来实现居中效果。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王佳斌

请作者喝杯咖啡 :)

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值