快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Vue3.0怎么实现放大镜效果-创新互联

本篇内容主要讲解“Vue3.0怎么实现放大镜效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue3.0怎么实现放大镜效果”吧!

创新互联,为您提供成都网站建设成都网站制作、网站营销推广、网站开发设计,对服务成都服务器托管等多个行业拥有丰富的网站建设及推广经验。创新互联网站建设公司成立于2013年,提供专业网站制作报价服务,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏心悦目的作品。 与客户共同发展进步,是我们永远的责任!

需要实现的效果是: 固定放大两倍,鼠标进入到左侧图片区域的时候,遮罩层显示,离开时,遮罩层隐藏。

Vue3.0怎么实现放大镜效果

 css中的cursor

  鼠标跟随效果如何实现: (子绝父相)绝对定位 +  修改top,left控制移动 

在@vueuse中,有一个工具方法:useMouseInElement


 

这是VueUse 官网上的用法,最后,别忘了return { target } 我一开始没return target,x,y,isOutside的值是 0,0,false,并不是变化的值。

鼠标的位置和遮罩的位置之间的关系: 

Vue3.0怎么实现放大镜效果

 
 //这是遮罩层 setup(){   //下面是实现鼠标跟随的代码 const layerStyle = reactive({       top: "0px",       left: "0px"     })     // 监听三个值的变化,watch第一个参数用数组     watch([elementX, elementY, isOutside], () => {       // layerStyle.left = elementX.value / 2 + "px"       // layerStyle.top = elementY.value / 2 + "px"       let top = elementY.value - 100       let left = elementX.value - 100         // 给遮罩元素赋值位置       if (top < 0) top = 0       if (top > 200) top = 200       if (left < 0) left = 0       if (left > 200) left = 200       layerStyle.top = top + "px"       layerStyle.left = left + "px"     })     return { elementX, elementY, isOutside, target, layerStyle }   }

遮罩区域不能超出左侧的父盒子,上面有两行是我注释掉的代码,为什么合起来写不行呢,因为后面我需要加判断时,会发现判断完之后  加px的时候,你会发现无从下手,上面这种分开写的话,top,left 只是一个数值,等计算完成后,再加单位。

 Vue3.0怎么实现放大镜效果Vue3.0怎么实现放大镜效果

放大效果如何实现:

css 样式里面有个 background-size属性,第一个参数指宽度,第二个参数指高度,可以放大图片

本身是 400 *400,那放大两倍就是 800*800

css 样式里面的 background-position-x, background-position-y 可以放大指定区域

关于background-position: x,y   第一个值是水平位置,第二个值是垂直位置

 这是右侧具有放大效果的div:

 

Vue3.0怎么实现放大镜效果

这是css代码,可以参考一下:

 .large {
   position: absolute;
    top: 0;
    left: 412px;
    width: 400px;
    height: 400px;
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
    background-repeat: no-repeat;
    background-size: 800px 800px;
    background-color: #f8f8f8;
 }

最后: 当鼠标移出左侧盒子区域,遮罩隐藏,右侧放大的盒子也隐藏

useMouseInElement的isOutSide属性可以监测到是否超出监测元素,v-show="!isOutSide" 即可

到此,相信大家对“Vue3.0怎么实现放大镜效果”有了更深的了解,不妨来实际操作一番吧!这里是创新互联建站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


文章标题:Vue3.0怎么实现放大镜效果-创新互联
网页地址:http://6mz.cn/article/dgesej.html

其他资讯