当前位置: 首页 > news >正文

网站宣传语整合营销传播策略

网站宣传语,整合营销传播策略,广告设计网站建设怎么做,青岛响应式网站开发Vue实现悬浮图片弹出大图预览弹窗,弹窗顶部与图片顶部平齐 需求背景 当前项目内某页面左侧展示图片列表,图片列表展示的均为小图。需求希望鼠标移动到对应图片时,右侧出现大图预览弹窗,且该弹窗顶部需与图片顶部平齐。同时弹窗要…

Vue实现悬浮图片弹出大图预览弹窗,弹窗顶部与图片顶部平齐

在这里插入图片描述

需求背景

当前项目内某页面左侧展示图片列表,图片列表展示的均为小图。需求希望鼠标移动到对应图片时,右侧出现大图预览弹窗,且该弹窗顶部需与图片顶部平齐。同时弹窗要在页面中展示完全,不能超出窗口高度导致被遮挡

核心实现

1.获取悬浮图片的位置信息

<div class="image_item" v-for="(item, index) in imgList" :key="index"><img:src="item"class="img"@mouseenter="e => handlePreview(e, item)"@mouseleave="preview.show = false"/>
</div>
// 获取当前图片顶部与视口顶部的距离top和底部的距离bottom
const handlePreview = (e, url) => {const targetRect = e.target.getBoundingClientRect()preview.bottom = window.innerHeight - targetRect.toppreview.top = targetRect.toppreview.url = urlpreview.show = true
}

2.动态计算大图预览弹窗位置

<!-- 样式绑定计算属性,根据悬浮图片位置变化 -->
<div class="module_view" v-show="preview.show" :style="previewStyle"><img :src="preview.url" class="img" />
</div>
const previewStyle = computed(() => {// 弹窗实际高度const previewHeight = 538const container = listRef.value// 容器与视口顶部距离const containerTop = container ? container.getBoundingClientRect().top : 0const previewTop = preview.topconst previewBottom = preview.bottom// 弹窗顶部与容器顶部的距离let top = previewTop - containerToplet bottom = previewBottom - previewHeight// 判断弹窗顶部与视口底部的距离是否能容纳整个弹窗if (bottom < 0) {// 无法容纳时,减小弹窗顶部距离容器顶部的距离从而抬升弹窗// 还需判断抬升后弹窗顶部与视口顶部是否仍大于0,否则设置为置顶距离,即负的容器与视口顶部距离top = previewTop + bottom > 0 ? top + bottom : 0 - containerTop}return {top: top + 'px'}
})

完整代码

<!-- 实现图片悬浮右侧展开预览大图弹窗功能,弹窗顶部与图片顶部平齐 -->
<template><div class="image_view"><div class="image_list" ref="listRef"><div class="image_item" v-for="(item, index) in imgList" :key="index"><img:src="item"class="img"@mouseenter="e => handlePreview(e, item)"@mouseleave="preview.show = false"/></div><div class="module_view" v-show="preview.show" :style="previewStyle"><img :src="preview.url" class="img" /></div></div></div>
</template><script>
import { defineComponent, ref, reactive, computed } from 'vue'
import { getImg } from '@/utils/imgExample'export default defineComponent({setup() {const imgList = ref(getImg(0, 12))const listRef = ref(null)const preview = reactive({top: 0,bottom: 0,url: '',show: false})const previewStyle = computed(() => {// 弹窗实际高度const previewHeight = 538const container = listRef.value// 容器与视口顶部距离const containerTop = container ? container.getBoundingClientRect().top : 0const previewTop = preview.topconst previewBottom = preview.bottom// 弹窗顶部与容器顶部的距离let top = previewTop - containerToplet bottom = previewBottom - previewHeight// 判断弹窗顶部与视口底部的距离是否能容纳整个弹窗if (bottom < 0) {// 无法容纳时,减小弹窗顶部距离容器顶部的距离从而抬升弹窗// 还需判断抬升后弹窗顶部与视口顶部是否仍大于0,否则设置为置顶距离,即负的容器与视口顶部距离top = previewTop + bottom > 0 ? top + bottom : 0 - containerTop}return {top: top + 'px'}})// 获取当前图片顶部与视口顶部的距离top和底部的距离bottomconst handlePreview = (e, url) => {const targetRect = e.target.getBoundingClientRect()preview.bottom = window.innerHeight - targetRect.toppreview.top = targetRect.toppreview.url = urlpreview.show = true}return {listRef,imgList,preview,previewStyle,handlePreview}}
})
</script><style lang="less" scoped>
.image_view {width: 100%;height: 100%;.image_list {position: relative;width: 404px;height: 100%;padding: 12px;border: 1px solid #ededed;display: flex;flex-wrap: wrap;gap: 8px;.image_item {width: 120px;height: 120px;border-radius: 4px;overflow: hidden;.img {width: 100%;height: 100%;object-fit: cover;}}.module_view {position: absolute;top: 0;right: -404px;width: 400px;height: 528px;background: #fff;box-shadow: 0 4px 10px 2px rgba(0, 0, 0, 0.16);padding: 8px;border-radius: 12px;}}
}
</style>
http://www.yayakq.cn/news/637682/

相关文章:

  • 为什么网站只能显示ip地址_不能显示域名 wordpressfrontpage做网站怎么样
  • 网站建设多久可以学会莱芜网站建设资情况介绍
  • 自己开发购物网站青岛seo优化
  • api模式网站开发介绍网页设计欣赏
  • 天津中小企业网站制作邮箱网站架构
  • 途牛旅游网站建设方案沈阳专业关键词推广
  • 内部网站建设计划网站打不开建设中哪的问题
  • 网站下载免费新版温州网页设计前端招聘
  • 企业网站搭建多少钱网站后台和移动开发
  • 美食网站开发现状全网搜索关键词查询
  • 最新备案网站查询小米发布会ppt模板
  • 网站域名和网站网址吗单页面网站建设
  • 涂料 网站 源码东营有做网站的公司
  • 做此广告的网站html个人主页模板
  • 花卉网站建设策划方案建设银行网页版登录入口
  • 深圳建网建网站家装公司网站建设网站
  • 京东企业集团网站建设方案怎么用ps做静态网站
  • 手机网站制作教程视频教程做网站用模板
  • 网站本地环境搭建软件wordpress添加留言版
  • 企业网站开发培训程序ui设计
  • 自己建个购物网站家教中介怎么利用网站来做的
  • 最好的机票网站建设建设小游戏网站空间类型选择
  • 怎么用PS做网站横幅asp 公司网站源码
  • 腾讯云做网站怎么样用jsp做一网站的流程图
  • 网站建设的7个基本流程搜索引擎优化的方法
  • 山东地产网站建设安徽教育云平台网站建设
  • 自己的网站怎么赚钱戴尔网站建设目标
  • 两学一做登录网站wordpress 分页数
  • 青海省城乡建设厅网站首页网站好坏怎么分析
  • 做seo的网站推广网页设计与制作题库及答案