原生JS实现的放大镜特效示例详解

作者: f673630174f6 | 来源:发表于2018-12-12 13:06 被阅读3次

    文章转载于:http://www.codingke.com/article/4316

    首先比如在做ecshop的二次开发,遇到一些jquery插件与ecshop的冲突,调整冲突的需要修改的地方又太多,修改起来得不偿失,故做了一个原生的js实现商品详情页面的放大镜效果,以避免冲突!下面介绍一下代码及实现过程:

    创建fangda.html文件

    在文件头部的<head></head>中添加文件的css样式,即:

    <style type="text/css">

    #div1 { width:304px; height:222px; position:relative; margin:30px auto 0px; border:2px solid red;}

    #div1 img{width:304px; height:222px;}

    #div1 span { width:100px; height:100px; background:red; left:0px;top:0px; position:absolute; display:none; filter:alpha(opacity:20); opacity:0.2;}

    .show { width:100%; height:100%; background:red; position:absolute; z-index:10px; filter:alpha(opacity:10); opacity:0.1; left:0px; top:0px; }

    #div2 {width:304px; height:222px; position:relative; display:none; overflow:hidden; margin:0px auto 0px;}

    #img1 { position:absolute;}

    </style>

    设置,显示在页面的内容

    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

    <title>JavaScript 图片放大代码</title>

    <body>

    <div id="div1">

    <img src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地图片路径 -->

    <span></span> <!-- 鼠标滑动 放大区域 -->

    <div class="show"></div>

    </div>

    <div id="div2"> <!-- 展示放大后的图片 -->

    <img id="img1" src="http://demo.jb51.net/js/2017/html5-canvas-fangdajing-codes/s1.jpg" /> <!-- 本地大图片路径 -->

    </div>

    </body>

    然后,添加js事件效果,添加在<head></head>中

    <script type="text/javascript">

    //通过页面加载事件,使页面加载完毕自动执行

    window.onload=function ()

    {

    var oDiv=document.getElementById('div1');

    var oShow=oDiv.getElementsByTagName('div')[0];

    var oSpan=oDiv.getElementsByTagName('span')[0];

    var oImg=document.getElementById('img1');

    oShow.onmouseover=function()

    {

    oSpan.style.display='block';

    oImg.parentNode.style.display='block';

    };

    oShow.onmouseout=function()

    {

    oSpan.style.display='none';

    oImg.parentNode.style.display='none';

    };

    oShow.onmousemove=function(ev)

    {

    var oEvent=ev||event;

    var x=oEvent.clientX-oDiv.offsetLeft-oSpan.offsetWidth/2;

    var y=oEvent.clientY-oDiv.offsetTop-oSpan.offsetHeight/2;

    //获得具体坐标

    if(x<0)

    {

    x=0;

    }

    else if(x>oShow.offsetWidth-oSpan.offsetWidth)

    {

    x=oShow.offsetWidth-oSpan.offsetWidth;

    }

    if(y<0)

    {

    y=0;

    }

    else if(y>oShow.offsetHeight-oSpan.offsetHeight)

    {

    y=oShow.offsetHeight-oSpan.offsetHeight

    }

    oSpan.style.left=x+'px';

    oSpan.style.top=y+'px';

    var percentX=x/(oShow.offsetWidth-oSpan.offsetWidth);

    var percentY=y/(oShow.offsetHeight-oSpan.offsetHeight);

    var oImgparent=oImg.parentNode;

    oImg.style.left=-percentX*(oImg.offsetWidth-oImgparent.offsetWidth)+'px';

    oImg.style.top=-percentY*(oImg.offsetHeight-oImgparent.offsetHeight)+'px';

    };

    };

    </script>

    这样就实现了,图片移上后的放大效果,同时由于没有引入其他的插件,移植性比较好,可以通过更改较少的代码,就较好地规避在其他项目和商城中的冲突。

    以上就是关于扣丁学堂HTML5培训之原生JS实现的放大镜特效示例详解,希望对小伙伴们有所帮助,想要了解更多内容的小伙伴可以登录扣丁学堂官网咨询。扣丁学堂有专业老师制定的HTML5学习路线图辅助学员学习,此外还有专业老师讲解的HTML5视频直播课供大家学习,想要学好HTML5开发技术的小伙伴快快行动吧。扣丁学堂H5技术交流群:673883249。

    相关文章

      网友评论

        本文标题:原生JS实现的放大镜特效示例详解

        本文链接:https://www.haomeiwen.com/subject/ijyuhqtx.html