使用el-amap-info-window遇到的问题

使用的这个库https://github.com/yangyanggu/vue-amap

想要滚动amapInfoWindow里的内容,但不触发地图缩放

默认滚动amapInfoWindow里的内容,会触发地图缩放。看了C站一个大佬的文章解决了。

amapInfoWindow会自动滚动到顶部

我的amapInfoWindow里面用了el-table,并且el-table里的每一行都加了勾选框。勾选后,amapInfoWindow会自动滚动到顶部。

我的解决思路是在上一个问题解决方案中的mousewheel监听中,记录弹框的scrollTop。

代码

复制代码
const infoWindowRef = ref()
const infoWindowObj = ref()
const infoWindowScrollTop = ref(0)
// 信息窗口打开后 el-amap-info-window的open回调方法
function handleInfoWindowOpen(){
  infoWindowObj.value = infoWindowRef.value.$$getInstance()
  // 弹框打开后地图禁止缩放
  infoWindowObj.value.on('mouseover', () => mapObj.value.setStatus({ zoomEnable: false }))
  infoWindowObj.value.on('mouseout', () => {
    mapObj.value.setStatus({ zoomEnable: true })
  })
  infoWindowObj.value.on('mousewheel', (e) => {
    const { originEvent } = e
    document.querySelector('.amap-info-content').scrollTop -= originEvent.wheelDelta / 5
    // 监听滚动高度
    infoWindowScrollTop.value = document.querySelector('.amap-info-content').scrollTop
  })
}

// 刷新table,防止滚动条跑到最上面
function refreshTable() {
  setTimeout(() => {
    document.querySelector('.amap-info-content').scrollTop = infoWindowScrollTop.value
  }, 0)
}

// 勾选框回调方法
function handleSelect(selection, row) {
  refreshTable()
  ......
  其他逻辑
 }
相关推荐
地方地方2 分钟前
JavaScript 类型检测的终极方案:一个优雅的 getType 函数
前端·javascript
加洛斯5 分钟前
AJAX 知识篇(2):Axios的核心配置
前端·javascript·ajax
Mintopia13 分钟前
开源数据集在 WebAI 模型训练中的技术价值与风险:当我们把互联网塞进显存
前端·javascript·aigc
写不来代码的草莓熊14 分钟前
vue前端面试题——记录一次面试当中遇到的题(3)
前端·javascript·vue.js
洛克大航海27 分钟前
Ajax基本使用
java·javascript·ajax·okhttp
用户9163574409529 分钟前
LeetCode热题100——11.盛最多水的容器
javascript·算法
凡大来啦44 分钟前
v-for渲染的元素上使用ref
前端·javascript·vue.js
eggcode1 小时前
Vue前端开发学习的简单记录
vue.js·学习
练习前端两年半1 小时前
🔍 你真的会二分查找吗?
前端·javascript·算法
晴殇i1 小时前
告别 localStorage!探索前端存储新王者 IndexedDB
前端·javascript·面试